RabbitMQ确保消息不丢失

本文介绍了如何确保RabbitMQ中消息不丢失,包括消息持久化、ACK确认机制、设置集群镜像模式和消息补偿机制。消息持久化需设置Exchange、Queue和Message为持久化;ACK机制确保消费端确认后服务端才删除消息;集群镜像模式提供高可用,但可能降低吞吐量;消息补偿机制用于弥补系统异常导致的丢失。
摘要由CSDN通过智能技术生成

RabbitMQ一般情况很少丢失,但是不能排除意外,为了保证我们自己系统高可用,我们必须作出更好完善措施,保证系统的稳定性,如何保证消息的绝对不丢失的问题?有以下几种方法:
                1.消息持久化
                2.ACK确认机制
                3.设置集群镜像模式
                4.消息补偿机制

1、消息持久化
        RabbitMQ的消息默认存放在内存上面,如果不特别声明设置,消息不会持久化保存到硬盘上面的,如果节点重启或者意外crash掉,消息就会丢失。所以就要对消息进行持久化处理。
        要做到消息持久化,必须满足以下三个条件,缺一不可:
                1.1 Exchange 设置持久化
                1.2 Queue 设置持久化
                1.3 Message持久化发送:发送消息设置发送模式deliveryMode=2,代表持久化消息

2、ACK确认机制
        多个消费者同时收取消息,比如消息接收到一半的时候,一个消费者死掉了(逻辑复杂时间太长,超时了或者消费被停机或者网络断开链接),这个时候就要使用Message acknowledgment 机制,就是消费端消费完成要通知服务端,服务端才把消息从内存删除。
        原因:
                这样即使一个消费者出了问题,没有同步消息给服务端,还有其他的消费端去消费,保证了消息不丢的case。

3、设置集群镜像模式
   

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值