幂等的实现方案

幂等在开发中的概念

对于同一个系统,在同样条件下,一次请求和重复多次请求对资源的影响是一致的,就称该操作为幂等的。

常见的幂等的例子

银行系统中,一笔转账应当只扣一次钱。

商城系统中,一个订单只能提交一次,提交了订单只扣一次钱。

论坛系统中,一个用户对一篇文章只能点一次赞。

幂等方案一:防重token令牌

针对客户端连续点击或者调用方的超时重试等情况,例如提交订单,此种操作就可以用 Token 的机制实现防止重复提交。

简单的说就是调用方在调用接口的时候先向后端请求一个全局 ID(Token),请求的时候携带这个全局 ID 一起请求(Token 最好将其放到 Headers 中),后端需要对这个 Token 作为 Key,用户信息作为 Value 到 Redis 中进行键值内容校验,如果 Key 存在且 Value 匹配就执行删除命令,然后正常执行后面的业务逻辑。如果不存在对应的 Key 或 Value 不匹配就返回重复执行的错误信息,这样来保证幂等操作。

Token 在何时生成,怎么生成?这是该机制的核心,比如在商城系统中,如果在提交订单的时候生成那么每次提交订单都会生成一个新的token,那就不幂等了。必须用户进入订单页面时就应该生成token,用户提交订单的时候携带者token一起提交,这样用户不管提交多少次订单最多就只能成功一次。

所以 Token 生成的时机必须保证能够使该操作具多次执行都是相同的效果才行

方案二:版本状态标志

给数据增加一个版本状态标志。通过这个状态标志,保证每个业务只在对应的状态下才会执行。如果标志已经进入了下一个状态,再有相同的请求来到当前标志时就不允许变更状态,保证了业务的幂等性。

此方案比较适合更新操作,比如下面的SQL

复制代码
update 账户表 set 余额 = 余额-100 , version = version+1 where 账户ID = id and version = 6

这样只会在version=6的时候才能成功扣减余额,重复执行该条SQL将不会生效,保证更新的幂等。但是需要额外的增加一个字段或者状态标志。

方案三:数据库唯一索引

利用数据库的唯一索引特性来实现幂等。

比如一个手机号只能创建一个账户,那么在手机号字段上创建一个唯一索引。同一个手机号无论提交多少次创建账户的请求都只能创建一个账户。

相关推荐
徐徐同学1 小时前
cpolar为IT-Tools 解锁公网访问,远程开发再也不卡壳
java·开发语言·分布式
Mr.朱鹏2 小时前
Nginx路由转发案例实战
java·运维·spring boot·nginx·spring·intellij-idea·jetty
白露与泡影4 小时前
2026版Java架构师面试题及答案整理汇总
java·开发语言
历程里程碑4 小时前
滑动窗口---- 无重复字符的最长子串
java·数据结构·c++·python·算法·leetcode·django
qq_229058015 小时前
docker中检测进程的内存使用量
java·docker·容器
我真的是大笨蛋5 小时前
InnoDB行级锁解析
java·数据库·sql·mysql·性能优化·数据库开发
钦拆大仁5 小时前
Java设计模式-单例模式
java·单例模式·设计模式
小手cool5 小时前
在保持数组中对应元素(包括负数和正数)各自组内顺序不变的情况下,交换数组中对应的负数和正数元素
java
笨手笨脚の5 小时前
深入理解 Java 虚拟机-04 垃圾收集器
java·jvm·垃圾收集器·垃圾回收
skywalker_115 小时前
Java中异常
java·开发语言·异常