探秘 RocketMQ 事务机制,如何保证消息零丢失,这些场景你熟悉吗?
引言
事务的概念就不用多说了,我相信阅读文章的童鞋都是有着非常深刻的认识。我们都知道MQ
可以实现微服务之间的异步以及解耦,那么引入MQ
之后,如何实现微服务之间的数据一致性是一个值得思考的问题。RocketMQ 事务消息正是解决这个问题的解决方案。另外事务消息也是为了解决消息丢失问题。
哪些场景会出现消息丢失
在分析RocketMQ
事务消息之前,我们先来分析下引入消息中间件之后,整个消息链路在哪些场景会出现消息丢失的异常情况。
当我们支付订单之后,我们账户的购物积分也会进行相应的积分调整。我们结合下面的订单服务、RocketMQ
、积分服务的简化交互图来看,我们来分析下整个链路中可能会出现的消息丢失问题。
场景 1:
在订单服务向 RocketMQ 发送订单成功生成的消息的时候,可能由于网络抖动的问题导致订单消息没能正常投递到 RocketMQ,导致消息丢失。
场景 2:
那么假如订单服务以及 RocketMQ 之间的网络没问题,消息正常被 RocketMQ 接收到了,那么会存在消息丢失的情况吗?答案是肯定的,这和 Rocket