文章目录
1、消息整体处理过程

这里我们将消息的整体处理阶段分为3个阶段进行分析:
- Producer发送消息阶段。
- Broker处理消息阶段。
- Consumer消费消息阶段。
Producer发送消息阶段
发送消息阶段涉及到Producer到broker的网络通信,因此丢失消息的几率一定会有,那RocketMQ在此阶段用了哪些手段保证消息不丢失了(或者说降低丢失的可能性)。
手段一:提供SYNC的发送消息方式,等待broker处理结果。
RocketMQ提供了3种发送消息方式,分别是:
- 同步发送:Producer 向 broker 发送消息,阻塞当前线程等待 broker 响应 发送结果。
- 异步发送:Producer 首先构建一个向 broker 发送消息的任务,把该任务提交给线程池,等执行完该任务时,回调用户自定义的回调函数,执行处理结果。
- Oneway发送:Oneway 方式只负责发送请求,不等待应答,Producer只负责把请求发出去,而不处理响应结果。
我们在调用producer.send方法时,不指定回调方法,则默认采用同
本文详细介绍了RocketMQ如何保证消息不丢失,包括Producer的SYNC发送、重试机制和多master模式,Broker的同步刷盘与主从同步双写,以及Consumer的At least Once机制和重试策略。同时,文章讨论了如何通过业务幂等性设计防止消息重复消费,提出了基于主键、全局ID和唯一键约束等多种解决方案。
订阅专栏 解锁全文
172万+

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



