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确认,任务将在故障状态下完成。
学习永不止境,技术成就梦想。