【HBZ分享】MQ如何保证消息重复消费问题

MQ如何保证消息重复消费问题?

总体来说就是幂等性校验

消息重复消费产生原因有哪些?

  1. 消息发送时出现网络抖动,从而导致没及时做ACK回复,生产者误以为失败从而进行重试。此时该消息会出现2次。
  2. 消费者消费过程中,存在消费失败,或者网络抖动,同样没及时响应ACK,使得MQ误以为消费失败,从而进行重试,也会导致重复消费

如何做幂等性校验?

  1. 如果存在订单号这种特殊数据,则可以在执行业务逻辑之前,通过订单号查一下数据库是否已存在 或 是否已对数据改动,如果已经做了相应操作,则该消息直接确认,不做任何逻辑。同时一定也要从数据库层面做限制,比如做【唯一约束】或【乐观锁】等限制,防止两个相同操作查询的时候时间很接近,恰好都没改动,导致bug产生。
  2. 如果只是普通数据,没有某个字段可依据,这种情况可以根据【消息ID】来做幂等性校验,因为每条消息都有唯一的ID,如果时消费重试,可以通过消息ID来做幂等性校验,比如可以通过redis或mysql记录该消息ID是否被消费,如果该消息已经被消费,那直接确认即可,无需在执行相应逻辑。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值