Java面试题20之论如何实现接口的幂等性(高并发情况下)

电商的前后端交互,下一步,登陆注册,由于网络原因的重复发送请求,同一资料发送多份

接口的幂等性:相同的资料进来只注册一个

唯一id:

每次操作,都根据操作和内容生成唯一的id,在执行之前先判断id是否存在,如果不存在,则执行

后续操作,并且保存到数据库或者redis等

服务器提供发送token的接口:

业务调用接口前先获取token,然后调用业务接口请求时,把token携带过去,服务器判断token是

否存在redist中,存在表示第一次请求,可以继续执行业务,执行业务完成后,最后把redis中的

token删除

建去重表:

将业务中有唯一标识的字段保存到去重表,如果表中存在,则表示已经处理过了。

版本控制:

增加版本号,当版本号符合时,才能更新数据

状态控制:

例如订单有状态已支付,未支付,支付中,支付失败,当处于未支付的时候才允许修改为支付中,等

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值