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

幂等性如何设计?

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

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

对订单的幂等性设计,可以使用订单号作为唯一索引,这样如果多次插入的话,就会报错 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);
}
相关推荐
hello早上好2 小时前
BeanFactory 实现
后端·spring·架构
白宇横流学长2 小时前
基于J2EE架构的在线考试系统设计与实现【源码+文档】
java·架构·java-ee
洛神灬殇4 小时前
【LLM大模型技术专题】「入门到精通系列教程」基于ai-openai-spring-boot-starter集成开发实战指南
网络·数据库·微服务·云原生·架构
Nejosi_念旧4 小时前
Vite 双引擎架构 —— Esbuild 概念篇
架构·前端框架
小鸡脚来咯4 小时前
redis分片集群架构
数据库·redis·架构
HyggeBest5 小时前
Mysql 宏观架构
mysql·架构
DemonAvenger5 小时前
Go GOGC环境变量调优与实战案例
性能优化·架构·go
大咖分享课5 小时前
容器安全最佳实践:云原生环境下的零信任架构实施
安全·云原生·架构
AllWe$5 小时前
互联网三高架构 一
架构
国家不保护废物7 小时前
🌟 React 魔法学院入学指南:从零构建你的第一个魔法阵(项目)!
前端·react.js·架构