RocketMQ消息的事务架构设计

1. 生产者执行本地事务,修改订单支付状态,并且提交事务

2. 生产者发送事务消息到broker上,消息发送到broker上在没有确认之前,消息对于consumer是不可见状态

3. 生产者确认事务消息,使得发送到broker上的事务消息对于消费者可见

4. 消费者获取到消息进行消费,消费完之后执行ack进行确认

5. 这里可能会存在一个问题,生产者本地事务成功后,发送事务确认消息到broker上失败了怎么办?这个时候意味着消费者无法正常消费到这个消息。所以RocketMQ提供了消息回查机制,如果事务消息一直处于中间状态,broker会发起重试去查询broker上这个事务的处理状态。一旦发现事务处理成功,则把当前这条消息设置为可见