消息队列如何确保消息不会丢失
一条消息从生产到消费可以分为以下三个阶段:
1.生产阶段:生产者发送消息到MQ
2存储阶段:MQ将消息存储
3消费阶段:消费者从MQ中消费
生产阶段:
生产阶段消息队列通过最常用的请求确认机制保证可靠性,当消息发送给broker如果成功则会得到一个确认响应,客户端得到响应则认为是一次成功的消息发送,若长时间得不到确认响应,则会重新发送消息,若不成功则会抛出异常或返回代表失败的值,在编写代码中,正确的处理返回值和异常,则能保证在生产阶段确保消息不丢失。
存储阶段:
在存储阶段正常运行,就不会出现消息丢失的情况,但当服务宕机或者进程死掉了,则会出现消息丢失的问题。
对于单个节点的broker,则可以当消息写入磁盘后,在回复确认响应,如果是多个节点,则可以当至少有两个节点将消息写入磁盘在进行回复响应
消费阶段:
在消费阶段则需要在业务逻辑都处理完之后在返回消费确认
1805

被折叠的 条评论
为什么被折叠?



