美文网首页
接口幂等性

接口幂等性

作者: 后厂村村长 | 来源:发表于2021-08-20 15:43 被阅读0次

幂等性

就是用户对于同一操作发起的一次请求或者多次请求的结果是一致的,不会因为多次点击而产生了副作用。

举个最简单的例子,支付场景,用户购买商品后支付,支付扣款成功,但是返回结果的时网络异常,此时钱已经扣了,用户再次点击按钮,此时会进行第二次扣款,返回结果成功,用户查询余额发现多扣钱了,流水记录也变成了两条。
在以前的单应用系统中,我们只需要把数据操作放入事务中即可,发生错误立即回滚,但是再响应客户端的时候也有可能出现网络中断或者异常等等。

什么情况下需要保证接口的幂等性?

在增删改查4个操作中,尤为注意就是增加或者修改。

A: 查询操作
查询对于结果是不会有改变的,查询一次和查询多次,在数据不变的情况下,查询结果是一样的。select是天然的幂等操作
B: 删除操作
删除一次和多次删除都是把数据删除。(注意,删除的数据存在和不存在,会导致数据库返回结果不一样,所以,不考虑返回结果的前提下,删除操作也是具有幂等性的)
C: 更新操作
修改在大多场景下结果一样,但如果是增量或减量修改则需要保证幂等性,如:
将表中id为XXX的记录的A字段值更新为1,这种操作不管执行多少次都是幂等的;
把表中id为XXX的记录的A字段值增加1,这种操作就不是幂等的。
D: 新增操作
新增在重复提交的场景下会出现幂等性问题,如以上的支付问题

支付场景的幂等设计示例:

方法1:
单次支付请求,也就是直接支付了,不需要额外的数据库操作了,这个时候发起异步请求创建一个唯一的ticketId,就是门票,这张门票只能使用一次就作废,具体步骤如下:

1、异步请求获取门票
2、调用支付,传入门票
3、根据门票ID查询此次操作是否存在,如果存在则表示该操作已被执行过,直接返回结果;如果不存在,支付扣款,保存结果。
4、返回结果到客户端
如果步骤4通信失败,用户再次发起请求,那么最终结果还是一样。

方法2:
分布式环境下各个服务相互调用。
先扣款,再更新订单。用户调用支付,扣款成功后,更新对应订单状态,然后再保存流水。而在这个地方就没必要使用门票ID了,因为会比较显的麻烦(订单涉及支付状态:未支付,已支付),步骤如下:

1、查询订单支付状态
2、如果已支付,直接返回结果
3、如果未支付,则支付扣款并保存流水
4、返回支付结果
如果步骤4通信失败,用户再次发起请求,那么最终结果还是一样的

幂等也称之为冲正,旨在保证客户端与服务端的交易一致性,避免多次扣款。

Token 令牌机制实现步骤:

  1. 生成全局唯一的token,存到redis或其他缓存系统中,token会在页面跳转时获取,存放到页面配置信息中,支付请求提交先获取token。
  2. 提交后,后台校验token,执行提交逻辑,提交成功同时删除token,生成新的token更新redis ,这样当第一次提交后token更新了,页面再次提交携带的token是已删除的token后台验证会失败不让提交。

token特点:一次有效性,可以限流
注意:redis要用删除操作来判断token,删除成功代表token校验通过,如果用select+delete来校验token,存在并发问题,不建议使用。

相关文章

  • SpringBoot接口幂等性实现的4种方案!

    目录 什么是幂等性 什么是接口幂等性 为什么需要实现幂等性 引入幂等性后对系统的影响 Restful API 接口...

  • 什么是接口的幂等性,如何实现接口幂等性?一文搞定

    每天一个知识点 什么是接口的幂等性,如何实现接口幂等性? (一)幂等性概念 幂等性原本是数学上的概念,用在接口上就...

  • 接口幂等性

    接口幂等性 什么是接口幂等性? 最简单想到的实现接口幂等性(重复提交)的操作是什么? 最简单稍靠谱的解决方案是什么?

  • 接口幂等性书目录

    1.幂等性定义 1.1 数学定义 1.2 HTTP规范的定义 2. 何种接口提供幂等性 2.1 HTTP支持幂等性...

  • 接口的幂等性的N种考虑

    分布式服务接口的幂等性如何设计 什么是幂等性 一个分布式系统中的某个接口,要保证幂等性,该如何保证?这个事儿其实是...

  • 接口幂等性

    什么是接口幂等性? 幂等是数学和计算机学的概念,常见于抽象代数中,即f(f(x)) = f(x)。简单来讲就是接口...

  • 接口幂等性

    学习缘由 幂等性这个词很高大上,但是又不明白其中含义,因此查资料进行理解学习。参考原文:路人甲java 什么是幂等...

  • 接口幂等性

    一、概念 当微服务之间调用时服务A向服务B重复发送消息或者用户多次点击导致重复操作数据库。 例如支付订单接口,如果...

  • 接口幂等性

    含义:接口可重复调用后,在调用方多次调用的情况下,接口最终得到的结果是一致的。 有些接口天然具备幂等性,如查询接口...

  • 接口幂等性

    描述 幂等性是指一次操作和多次操作产生的结果一致。操作后的结果有三种状态,成功、失败、超时。在超时重试时就需要该操...

网友评论

      本文标题:接口幂等性

      本文链接:https://www.haomeiwen.com/subject/obdnbltx.html