通过ConsumeContext --Masstransit发布命令处理程序的命令结果

时间:2015-12-30 21:36:46

标签: c# rabbitmq masstransit rabbitmq-exchange

我为masstransit配置了一个webapi控制器。这样的事情。

_busControl = MassTransit.Bus.Factory.CreateUsingRabbitMq(x =>
            {
                x.Host(new Uri("rabbitmq://localhost/"), h =>{ });
            });
            _busControl.Start();

并且控制台应用程序是我的服务器,它正在监听我的命令/事件 -

 var BusControl = Bus.Factory.CreateUsingRabbitMq(cfg =>
             {
                 var host = cfg.Host(new Uri("rabbitmq://localhost/"), h =>
                {
                    //h.Username("guest");
                    //h.Password("guest");
                });

                 cfg.ReceiveEndpoint(host, "create_product_queue", config => config.Consumer<CreateInventoryProductItemHandler>());
                 cfg.ReceiveEndpoint(host, "ProductItemCreatedEvent", config => config.Handler<ProductItemCreatedEvent>(async context => await Console.Out.WriteLineAsync($"Product Item Id -----{context.Message.ProductItemId} "))); <---- this never gets executed . 
             });
            BusControl.Start();

控制器动作类似于 -

[HttpPost("product")]
        public async Task<IActionResult> Post([FromBody] Product Product)
        {
            var endpoint = await Startup.Bus.GetSendEndpoint(new Uri("rabbitmq://localhost/create_product_queue"));
            await endpoint.Send<CreateInventoryProductItem>(new
            {
                ProductName = Product.ProductName,
                PartNumber = Product.PartNumber,
                ManufactureDate = Product.ManufacturedDate
            });
            return new HttpStatusCodeResult(StatusCodes.Status202Accepted);
        }

,处理程序是 -

public async Task Consume(ConsumeContext<CreateInventoryProductItem> context)
        {
            CreateInventoryProductItem Command = context.Message;
            Product Product = await Context.SaveAsync(new Product(Command.ProductName
                , Command.PartNumber
                , Command.ManufacturedDate));
            await context.Publish<ProductItemCreatedEvent>(Product.Id); <--- problem area

        }

现在我的情景是。

  1. 创建命令对象。
  2. 从新创建的实体框架Context.SaveAsync()方法中获取产品ID。
  3. 将ProductId发布到总线,以便其他听众可以收听此产品ID并采取相应行动。

    我试图找出在这种情况下应用的最佳模式。

  4. 现在问题始于 - await context.Publish<ProductItemCreatedEvent>(Product.Id);这一行。它试图无限地一次又一次地发布到同一个队列。结果相同的Product对象被插入了数百次(相当蹩脚,我知道因为没有唯一的约束,但这不是问题),所发生的是我的命令处理程序,尽管强类型它无限期地执行。如何摆脱这种局面。我对masstransit概念很陌生。

    所以有人可以解释为什么会发生这种情况。

1 个答案:

答案 0 :(得分:1)

所以问题是你需要将一个对象传递给你正在使用的Publish重载:

await context.Publish<ProductItemCreatedEvent>(Product.Id);

如果ProductItemCreatedEvent包含两个属性IdDescription,您将创建一个匿名对象来初始化界面:

await context.Publish<ProductItemCreatedEvent>(new
{
    Id = Product.Id,
    Description = Product.Description,
});

这样,传递了一个具有属性的对象,可以为事件接口启动动态生成的后备类。