MassTransit的IConsumeObserver应该如何使用?

时间:2015-10-02 18:54:48

标签: masstransit

我在使用MassTransit3中的IConsumeObserver时遇到问题。我编写了一个非常简单的观察者,它只是在消费前和消费后向控制台打印消息,但消息没有显示,似乎代码永远不会被调用(其中的断点不会被触及) )。

public class ConsumeObserver : IConsumeObserver
{
    public async Task ConsumeFault<T>(ConsumeContext<T> context, Exception exception) where T : class
    {
        await Console.Out.WriteLineAsync("ConsumeObserver.ConsumeFault");
    }

    public async Task PostConsume<T>(ConsumeContext<T> context) where T : class
    {
        await Console.Out.WriteLineAsync("ConsumeObserver.PostConsume");
    }

    public async Task PreConsume<T>(ConsumeContext<T> context) where T : class
    {
        await Console.Out.WriteLineAsync("ConsumeObserver.PreConsume");
    }
}

奇怪的是,我已经实现了一个类似的接收观察者,并且它会像我期望的那样被调用。

public class ReceiveObserver : IReceiveObserver
{
    public async Task PostReceive(ReceiveContext context)
    {
        await Console.Out.WriteLineAsync("ReceiveObserver.PostReceive");
    }

    //Other methods omitted for brevity        
}

我将观察者连接到公共汽车,如下所示:

        var bus = Bus.Factory.CreateUsingRabbitMq(cfg =>
        {
            var host = cfg.Host(new Uri(ConfigurationManager.AppSettings["RabbitMQHost"]), h => { });

            cfg.ReceiveEndpoint(host, "Subscriber", e =>
            {
                e.Consumer<SomethingHappenedConsumer>();
                e.UseRetry(Retry.Interval(2, TimeSpan.FromSeconds(1)));
            });
        });

        //The callbacks in this observer get called...
        bus.ConnectReceiveObserver(new ReceiveObserver());

        //...but not in these two observers
        bus.ConnectConsumeObserver(new ConsumeObserver());
        bus.ConnectConsumeMessageObserver(new ConsumeSomethingHappenedObserver());

感谢任何理解方面的帮助。我已将完整的资源放在GitHub上。

1 个答案:

答案 0 :(得分:1)

目前,必须在每个接收端点上注册ConsumeObserver(使用.13)。因此,通过将观察者连接到总线,接收端点消耗的消息是不可见的,除非观察者也连接到接收端点。

为了使其与ReceiveObserver保持一致,我将更新总线代码,以便其他观察者也连接到接收端点。