幂等问题

幂等:就是指多接口的多次调用所产生的结果和只调用一次是一致的。

参考:
分布式系统—幂等性设计

场景

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)
对外接口保证幂等

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值