16 RabbitMQ怎么保证投递消息不丢失

RabbitMQ一般情况下很少丢失,但是不能排除意外,为了保证我们自己的系统高可用,我们必须做好完善的措施,保证系统的稳定性。 1,消息持久化 2,ACK确认机制 3,设置集群镜像模式 4,消息补偿机制 第一种: 消息持久化 RabbitMQ 的消息默认存放在内存上面,如果不特别声明设置,消息不会持久化保存到硬盘上面的,如果节点重启或者意外crash掉,消息就好丢失。所以也要对消息进行持久化处理:1,Exchange 设置持久化,2,Queue进行持久化,3,Message持久化发送: 发送消息设置发送模式deliveryMode=2,代表持久化消息。 第二种: Ack确认机制 多个消费者同时收取消息,比如消息接收到一半的时候,一个消费者死掉了(逻辑复杂时间太长,超时了或者消费被停机了或者网络断开链接),为了保证消息不丢失就需要使用 Message acknowledgment机制,就是消费端消费完成要通知服务端,服务端才会把消息从内存删除。 这样就解决了,及时一个消费者出了问题,没有同步消息给服务端,还有洽谈的消费端去消费,保证了消息不丢的case. 第三种:设置集群镜像模式: RabbitMQ有三种部署模式分别是:1,单节点模式: 最简单的情况,非集群的模式,节点挂了,消息就不能用了。业务可能瘫痪只能等待。 2,普通模式: 默认的集群模式,某个节点挂了,改节点上的消息不能用,有影响的业务瘫痪,只能等待节点恢复重启(必须持久化消息情况下)。 3,镜像模式:把需要的队列做成镜像队列,存在于多个节点,属于RabbitMQ的HA方案 第四种:消息补偿机制
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章