RabbitMQ幂等性概念及业界解决方案(六)

一、什么是幂等性

可以参考数据库乐观锁机制,比如执行一条更新库存的 SQL 语句,在并发场景,

为了性能和数据可靠性,会在更新时加上查询时的版本,并且更新这个版本信

息。可能你要对一个事情进行操作,这个操作可能会执行成百上千次,但是操作

结果都是相同的,这就是幂等性。

比如,我们执行一条更新库存的sql语句:update table set count = count -1 where id = 1
在高并发的场景下,就拿秒杀系统来做说明,现在商品就剩下一个了。如果我们

执行:update table set count = count -1 where id = 1这个sql语句的时候,高并发

情况会导致库存成为负数,这种操作是有问题的。现在用乐观锁:在查询的时

候,假设查询的版本号是1,在更新的时候拿着版本号作为更新条件即where

version=1来更新。高并发时候,第一个执行完成后,version+1了。当第二条更新

,发现已经不是1了就更新不了。

二 幂等性保障

在海量订单产生的业务高峰期间,如何避免消息的重复消费问题?

消费端实现幂等性,就意味着,我们的消息永远不会消费多次,即使我们收
  
到多条一样的消息

三 业界主流的幂等性操作

唯一ID+指纹码机制,利用数据库主键去重

名称解释

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值