常见场景题-幂等性该如何设计?

幂等性如何设计?

答:幂等性的设计有以下几种方案:

方案一:唯一索引或唯一组合索引

对订单的幂等性设计,可以使用订单号作为唯一索引,这样如果多次插入的话,就会报错 DuplicatedKeyException, 那么我们就可以捕获该错误,来返回友好提示。

方案二:基于 Redis setnx

使用 Redis 的 setnx 来进行实现幂等性,setnx 如果设置成功,表示第一次来请求,如果设置失败表示重复请求,setnx 设置时也记得设置过期时间

方案三:Token + Redis

针对调用方重试接口的情况,例如重复提交订单,这种幂等性设计可以使用 Token 机制来防止重复提交。

调用方在调用接口时,先向后端请求一个 Token,该 Token 存储在 Redis 中并设置过期时间,在调用时携带上 Token(放入Header存储),后端在 Redis 中检查该 Token 是否存在,如果存在表示是第一次请求,删除token中的缓存**(使用 lua 脚本,保证操作的原子性)**,如果不存在,表示重复请求,直接返回。

如果第一次调用接口失败了,可以通过设计来重新生成 token,再次尝试调用。

java 复制代码
public void invoke(){
  String token = genToken();
  // 提交订单信息
  submitOrder(token, order);
}
相关推荐
yunteng52116 小时前
通用架构(同城双活)(单点接入)
架构·同城双活·单点接入
麦聪聊数据16 小时前
Web 原生架构如何重塑企业级数据库协作流?
数据库·sql·低代码·架构
程序员侠客行17 小时前
Mybatis连接池实现及池化模式
java·后端·架构·mybatis
bobuddy18 小时前
射频收发机架构简介
架构·射频工程
桌面运维家19 小时前
vDisk考试环境IO性能怎么优化?VOI架构实战指南
架构
一个骇客20 小时前
让你的数据成为“操作日志”和“模型饲料”:事件溯源、CQRS与DataFrame漫谈
架构
鹏北海-RemHusband21 小时前
从零到一:基于 micro-app 的企业级微前端模板完整实现指南
前端·微服务·架构
2的n次方_1 天前
Runtime 内存管理深化:推理批处理下的内存复用与生命周期精细控制
c语言·网络·架构
前端市界1 天前
用 React 手搓一个 3D 翻页书籍组件,呼吸海浪式翻页,交互体验带感!
前端·架构·github
文艺理科生1 天前
Nginx 路径映射深度解析:从本地开发到生产交付的底层哲学
前端·后端·架构