Fork me on GitHub

10,EasyNetQ-发布确认

默认的AMQP发布不是事务性的,并且不能保证您的消息实际上会到达代理。 AMQP指定了一个事务性发布,但是对于RabbitMQ来说,它非常慢,我们还没有通过EasyNetQ API支持。 对于高性能保证交付,建议您使用“发布确认”。 简而言之,这是AMQP的扩展,当代理成功收到您的消息时,它会提供回调

'成功收到'是什么意思? 这取决于 ...

  • transient(瞬时)消息在队列入场时被确认。
  • 持久性消息一旦被保存到磁盘或者在每个队列上被使用,就会被确认。
  • 直接发布不可修改的瞬态消息。

通过在连接字符串上设置publisherConfirms = true来启用发布确认:

bus = RabbitHutch.CreateBus("host=localhost;publisherConfirms=true;timeout=10");

同步bus.Publish(..)方法将在返回之前等待确认。 在超时期限之前未确认(也在连接字符串中配置)将导致引发异常。 发布确认同步发布方法会显着减慢。 如果性能问题,您应该考虑使用PublishAsync方法:

bus.PublishAsync(new MyMessage
    {
        Text = "Hello World"
    }).ContinueWith(task =>
        {
            // 这只会检查完成的任务IsCompleted是否成立,即使对于我们使用if(task.IsCompleted &&!task.IsFaulted)来检查成功的故障状态任务
            if (task.IsCompleted) 
            {
                //Console.Out.WriteLine("{0} Completed", count);
            }
            if (task.IsFaulted)
            {
                Console.Out.WriteLine("\n\n");
                Console.Out.WriteLine(task.Exception);
                Console.Out.WriteLine("\n\n");
            }
        });

这将在收到确认之前返回。 如果未收到确认或NACK确认,任务将在故障状态下完成。

 

posted on 2018-03-25 20:10  *Hunter  阅读(395)  评论(0编辑  收藏  举报

导航

AmazingCounters.com