幂等:就是指多接口的多次调用所产生的结果和只调用一次是一致的。
参考:
分布式系统—幂等性设计
场景
1.业务上比如支付两次,重复扣款,重复插入数据等
2.消息队列中重复消费
3.web接口上失败重试
http协议幂等性
幂等:get、put、delete
非幂等:post
常见保证幂等的手段
1.MVCC(乐观锁)
带条件更新,判断是否是期待的版本号
2.唯一索引(RabbitMQ、数据库)
3.悲观锁
4.select+insert
先查询一下是否执行过,再进行更新(核心高并发不要用这种方式)
5.状态机
缓存中间件中就是利用了状态机方式实现幂等。
cud操作中设置了3个状态:更新前、更新中、更新后
若处于后两个状态则不更新
6.一次性token
防止页面重复提交
集群:token+redis
单JVM:token+jvm内存
7.序列号(Kafka)
对外接口保证幂等