首页 > 其他分享 >幂等性解决方案

幂等性解决方案

时间:2023-03-15 23:22:59浏览次数:34  
标签:解决方案 多次 update 比如 MQ https 数据

一、什么是幂等性

幂等性就是同一个操作执行多次,产生的效果一样。多如此请求,多次消费不会造成程序逻辑异常。

常见的请求有如下几种,他们的幂等性如下:

  • select查询天然幂等;
  • delete删除也是幂等,删除同一个数据多次其效果一样;
  • update直接更新某个值时,幂等;
  • update更新累加操作的的结果,非幂等;
  • insert操作会每次都新增一条,非幂等

 

二、产生幂等性问题的原因

第一种是,用户的重复提交或用户的恶意攻击;

第二种是,分布式系统中,为了避免数据丢失,采用的超时重试机制。

 

三、如何解决

第1种方案,就是使用数据库的唯一约束来实现幂等,比如对于数据插入类的场景,比如创建订单,因为订单号肯定是唯一的,所以如果是多次调用就会触发数据库的唯一约束异常,从而避免一个请求创建多个订单的问题。

第2种方案,就是使用 Redis 提供的 setNX 指令,比如对于 MQ 消费的场景,为了避免 MQ 重复消费导致数据多次被修改的问题,可以在接受到 MQ 的消息时,把这个消息ID通过 setNX 写入到 Redis 中,一旦这个消息被消费过,就不会再次消费。

第3种方案,使用状态机来实现幂等,所谓的状态机是指一条数据的完整运行状态的转换流程,比如 ,因为它的状态只会向前变更,所以多次修改同一条数据的时候,一旦状态发生变更,那么对这条数据修改造成的影响只会发生一次。

update table set status =支付成功 where status=支付中 and id = ID

当然,除了以上3种常用的之外,还可以基于 Token 机制或者增加去重表等方法来实现,但是不管是什么方法,无非就是两种思路,要么就是接口只允许调用一次,比如唯一约束、基于分布式锁机制。要么就是对数据的影响只会触发一次,比如乐观锁等。

 

文章来源: https://blog.csdn.net/qq_43602280/article/details/121704243      https://www.cnblogs.com/gustavo/p/16608034.html       https://www.zhihu.com/question/534651475/answer/2542377973

 

标签:解决方案,多次,update,比如,MQ,https,数据
From: https://www.cnblogs.com/loquat6/p/17220568.html

相关文章