接口的幂等性如何设计?

需要使用幂等的场景

  • 前端重复提交
  • 接口超时重试
  • 消息队列重复消费

解决方案

  1. token机制:①客户端请求获取token,服务端生成一个唯一ID作为token存在redis中;②客户端第二次请求时携带token,服务端校验token成功则执行业务操作并删除token,服务端校验token失败则表示重复操作。  
  2. 基于mysql:①新建去重表;②服务端将客户端请求时提交的部分信息放入表中,其中有唯一索引字段;③成功插入则没有重复请求,插入失败则重复请求。
  3. 基于redis:①客户端请求服务端拿本次请求的标识字段;②服务端将标识字段以setnx方式存入redis并设置过期时间;③设置成功则说明非重复操作,设置失败则表示重复操作。
  4. 状态机、悲观锁、乐观锁等。

以上参考:https://mp.weixin.qq.com/s/74QYS_5K1c-XK8tsTNkb4g

原文地址:https://www.cnblogs.com/smallzhen/p/14687483.html