MQ消费端如何保证幂等性?

承接上文RabbitMQ、RocketMQ、Kafka性能为何差距如此大?

MQ消息重复,如何保证消费端的幂等性

MVCC(多版本并发控制)方式

这是乐观锁的一种实现,每一次要对库存的数量+1,

MQ消费端如何保证幂等性?_第1张图片

这种方式解决消息重复没有问题,但不太好,因为消息在生产的时候,生产者要判断id是不是重复的,如果是重复的,下一次version+1,相当于浏览器点击了2次。

这种方式虽然可以解决消息幂等性问题,但要求生产者也要改动,一般情况下不推荐。

去重表

并发不是很高用mysql实现,并发高用redis实现。

在表上要构建一个唯一性的索引,电商平台有一个订单id,适合做唯一性的索引,比如在进行库存扣减的时候,每次针对goods表的操作都会涉及到一笔订单,下了单或退了单,那操作的订单id是唯一的。

MQ消费端如何保证幂等性?_第2张图片

如果重复insert就会报已存在该订单id,捕获异常,返回1,就表示MQ中已消费完这条消息了。

用redis setnx命令也可以实现,假设mq中有2条一摸一样的数据,第一条消息保存到redis,进行具体的业务处理,第二条消息,先查询redis中是否存在,存在返回0,此时也不需要捕获异常了。

如果是分布式系统,需要使用分布式锁,

MQ消费端如何保证幂等性?_第3张图片

MQ消费端如何保证幂等性?_第4张图片

这是采用redis分布式锁实现的去重。

MQ消费端如何保证幂等性?_第5张图片

这是mysql实现的去重。

你可能感兴趣的:(平凡人笔记,数据库,java,redis,mq消息幂等性)