幂等的实现方案

幂等在开发中的概念

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

常见的幂等的例子

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

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

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

幂等方案一:防重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将不会生效,保证更新的幂等。但是需要额外的增加一个字段或者状态标志。

方案三:数据库唯一索引

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

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

相关推荐
c++之路16 分钟前
C++20概述
java·开发语言·c++20
Championship.23.2420 分钟前
Linux Top 命令族深度解析与实战指南
java·linux·服务器·top·linux调试
橘子海全栈攻城狮35 分钟前
【最新源码】养老院系统管理A013
java·spring boot·后端·web安全·微信小程序
逻辑驱动的ken41 分钟前
Java高频面试考点18
java·开发语言·数据库·算法·面试·职场和发展·哈希算法
冷雨夜中漫步1 小时前
Claude Code源码分析——Claude Code Agent Loop 详细设计文档
java·开发语言·人工智能·ai
直奔標竿1 小时前
Java开发者AI转型第二十六课!Spring AI 个人知识库实战(五)——联网搜索增强实战
java·开发语言·人工智能·spring boot·后端·spring
one_love_zfl2 小时前
java面试-微服务组件篇
java·微服务·面试
一只大袋鼠2 小时前
Java进阶:CGLIB动态代理解析
java·开发语言
环流_2 小时前
HTTP 协议的基本格式
java·网络协议·http
爱滑雪的码农2 小时前
Java基础十三:Java中的继承、重写(Override)与重载(Overload)详解
java·开发语言