场景:二手项目的订单支付完成,需要发送消息给卖家(需要发货)
- 发送消息给卖家,提示卖家发货
- 消息表新增预发送状态的消息记录 消息并未发送rabbitmq
- 订单修改状态,事务提交 只是本地事务
- 真正发送消息到rabbimq
- rabbitmq回调确认收到消息的ack给业务模块,这时修改消息状态为消息发送已完成状态
- rabbitmq消费者 消费完,再恢复消费完成的ack 消费者消费的时候需要确认订单是否已经是完成状态防止第二步失败
上述场景中,可能出现的问题,订单状态已修改,但是没有收到消息发送完成的ack(消息发送失败导致),需要起定时任务进行查询消息未完成的列表,然后进行重试发消息的动作,直到发送消息的ack收到为止
上述方案中使用了本地事务,如果想省去本地事务,定时任务扫描预发送状态的消息时,需要查询订单是否已支付状态。如果未支付,直接废弃消息记录。否则再发送消息