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

幂等性如何设计?

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

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

对订单的幂等性设计,可以使用订单号作为唯一索引,这样如果多次插入的话,就会报错 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);
}
相关推荐
小股虫5 分钟前
从Tair虚拟桶到数据库分库分表:解耦逻辑与物理的架构艺术
数据库·架构·解耦
是一个Bug16 分钟前
云原生架构
云原生·架构
lusasky27 分钟前
基于 LangChain 的海量 API 动态检索与调用架构
网络·架构·langchain
Gavin在路上1 小时前
企业架构之深度解析企业架构与流程架构的共生关系(3)
架构
GIOTTO情1 小时前
Infoseek 危机公关系统技术实现深度解析:AI 驱动的全链路舆情处置架构与工程实践
人工智能·架构
Joy T2 小时前
【快速入门】提示工程(PE,Prompt Engineering):大模型时代的自然语言编程范式
架构·llm·prompt·人机交互
tap.AI2 小时前
RAG系列(四)高级 RAG 架构与复杂推理
人工智能·架构
七夜zippoe2 小时前
多模态图文跨模态检索实战教程
架构·多模态·faiss·模型·图文
智驱力人工智能2 小时前
仓库园区无人机烟雾识别:构建立体化、智能化的早期火灾预警体系 无人机烟雾检测 无人机动态烟雾分析AI系统 无人机辅助火灾救援系统
人工智能·opencv·算法·目标检测·架构·无人机·边缘计算
乾元3 小时前
LLM 自动生成安全基线与等保合规初稿——把“网络工程事实”转译为“可审计的制度语言”
运维·网络·人工智能·python·安全·架构