在本节中,咱们将看看任何消息系统中可能出现的各类错误状况,并查看EasyNetQ如何处理它们。windows
1,个人订阅服务死亡缓存
你已经写了一个订阅了个人NewCustomerMessage的windows服务。 若是服务失败会发生什么? 为了提升效率,EasyNetQ为订阅实现了一个内部内存队列。 消息从RabbitMQ经过网络接收并放置在该队列中。 单个订阅线程将消息依次从队列中取出,并将它们传递给您提供的回调。 一旦回调完成,EasyNetQ将“Ack”发送回RabbitMQ。 在收到'Ack'以前,消息不会从RabbitMQ队列中删除。 若是您的服务在处理消息时死掉,则消息(以及EasyNetQ内存队列中的全部消息)将保留在RabbitMQ队列中。 一旦你的服务从新链接,消息将被从新发送。服务器
2,个人订阅者消息发布速度比发布时慢网络
EasyNetQ使用RabbitMQ的服务质量设置将预设计数设置为一些合理的设置(当前为50)。 这意味着用户的内存队列中永远不会有超过50条消息。 这能够防止在订阅应用程序中发生内存不足异常。 一旦未发出消息的计数达到此级别,RabbitMQ将中止发送它们,并将它们留在其内部队列中。 固然,最终这个队列会占用RabbitMQ服务器机器上的全部磁盘空间。 您应该进行一些监测以确保在发生这种状况以前收到警报。线程
3,个人用户和RabbitMQ Broker之间有网络故障设计
正如在“链接到RabbitMQ”一节中所描述的,EasyNetQ实现了一个延迟链接策略。它假定代理并不老是可用的。当您第一次使用RabbitHutch链接到代理时。CreateBus, EasyNetQ进入一个链接尝试循环,若是在链接字符串中指定的地址上没有可用的代理,您将看到“尝试链接”的信息消息。用户可使用总线订阅。即便没有代理,也要订阅。订阅细节由EasyNetQ缓存。当代理成为可用的链接循环时,将创建与代理的链接,并建立全部缓存的订阅。代理
一样,当EasyNetQ与代理失去链接时,它将返回到链接循环,您将在日志中看到“尝试链接”消息。 一旦链接从新创建,缓存的用户再次被建立。 这样作的结果是,您可让您的订户在网络链接不可靠或您须要退出RabbitMQ代理的环境中运行。日志
4,个人订阅回调在消费时引起异常blog
若是您的订阅回调引起异常,则EasyNetQ将接收正在使用的消息并将其包含在特殊的错误消息中。 该错误消息将发布到EasyNetQ错误队列(名为EasyNetQ_Default_Error_Queue)。 您应该监视错误队列中的任何消息。 错误消息包括从新发布原始消息所需的全部信息以及异常的类型,消息和堆栈跟踪。 您可使用EasyNetQ.Hosepipe实用程序从新发布错误消息。 请参阅下面的EasyNetQ.Hosepipe一节。队列