RocketMQ 是如何使用事务消息保证发送消息不丢失的

前言

    rocketmq 消息队列在大部分业务系统中都会用到(如下图),服务A和服务B系统通过mq进行业务解耦;服务A处理完业务之后,发一条消息到rocketmq,服务B从rocketmq拉去消息进行消费。

 上面这个流程会有下面几个问题:   

 1.如果服务A写数据库成功了,还没来得及发送消息就宕机了,这就会导致服务B永远消费不了消息,出现了数据不一致问题;

 2. 服务A写数据库成功,发送mq消息失败,也会出现服务B消费不了消息的情况;

3.服务A写数据库成功,发mq消息成功了,但是服务A事务由于异常回滚了,服务B消费了消息。

 针对上面的几个问题, 我们在生产开发中如何解决呢?

 

1.重试+回滚

针对第二个问题,我们可以使用重试加回滚的方式解决;先写本地事务,然后发送mq消息,如果发送失败再重试几次,重试也是失败就回滚本地事务。

 public  void doService() {
        //执行本地事务
        server.doLocalTransaction();

   
  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值