需要使用幂等的场景:
- 前端重复提交
- 接口超时重试
- 消息队列重复消费
解决方案:
- token机制:①客户端请求获取token,服务端生成一个唯一ID作为token存在redis中;②客户端第二次请求时携带token,服务端校验token成功则执行业务操作并删除token,服务端校验token失败则表示重复操作。
- 基于mysql:①新建去重表;②服务端将客户端请求时提交的部分信息放入表中,其中有唯一索引字段;③成功插入则没有重复请求,插入失败则重复请求。
- 基于redis:①客户端请求服务端拿本次请求的标识字段;②服务端将标识字段以setnx方式存入redis并设置过期时间;③设置成功则说明非重复操作,设置失败则表示重复操作。
- 状态机、悲观锁、乐观锁等。
以上参考:https://mp.weixin.qq.com/s/74QYS_5K1c-XK8tsTNkb4g