RocketMq如何保证消息不丢失

RocketMq确保消息不丢失主要从Producer、Broker和Consumer三个方面采取措施。Producer使用同步发送、重试机制和多Master模式;Broker通过同步刷盘、同步Slave策略保证;Consumer采用At least Once和消费重试确保消息可靠性。
摘要由CSDN通过智能技术生成

可以从三个阶段进行分析
Producer发送消息阶段
Broker处理消息阶段
Consumer消费消息阶段
(1)、Producer 发送消息阶段涉及到Broker的网络通信,因此丢失消息的几率一定会有,那RocketMq在此阶段用了哪些手段保证消息不丢失呢?
手段一:提供SYNC的发送消息方式,等待broker处理结果
RocketMq提供了3种发送消息的模式,分别是:
同步发送、异步发送、oneway发送
同步发送:Producer 向broker 发送消息,阻塞当前线程等待broker响应发送结果
异步发送:Producer 首先构建一个向broker发送消息的任务,把该任务提交给线程池,等执行完该任务时,回调用户自定义的回调函数,执行处理结果
oneway发送:oneway发送方式只负责发送请求,不等待应答,Producer只负责把请求发送出去,而不处理响应结果。
我们在调用send方法时,不指定回调方法,默认采用同步发送方式,这是丢失几率最小的一种发送方式
手段二:发送消息如果失败或者超时,则重新发送
当发送消息发生异常的时候重新循环发送,默认重试三次,重试次数可以通过 producer指定,只有同步发送的方式才会重试
手段三:broker提供多master模式,即使某台broker宕机了,保证消息可以投递到另外一台正常的broker上。
总结:producer消息发送方式利用同步发送+重试机制+多个master节点,尽可能减少消息丢失的可能性

    Broker处理消
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值