【幂等性】基本概念介绍

摘自 理解HTTP幂等性- Todd Wei - 博客园

定义:对同一个系统,使用同样的条件,一次请求和重复的多次请求对系统资源的影响是一致的

例子:对一个资源发送多次读请求,返回的结果肯定相同(只要别的用户不修改,即使资源被修改也不是因为读请求产生的)

问题引入

假设有一个从账户取钱的远程 API 如下所示。

// 从account_id账户上扣除amount数额的钱,然后返回操作结果
boolean withdraw(account_id, amount);

存在这么一种情况:用户发送该请求时,服务器成功扣除 amount 数额的钱,然后返回 ok 时由于网络等原因该返回值丢失。用户会认为请求失败,又发送一次请求,此时账户实际上扣除了两次钱。如下图所示

问题引入

解决方法

  1. 使用事务机制
  2. 幂等设计

方案二:幂等设计

int create_ticket();
boolean idempotent_withdraw(ticket_id, account_id, amount);
  • create_ticket() 的语义是获取一个服务器端生成的唯一的处理号 ticket_id,它将用于标识后续的操作。
  • idempotent_withdraw()withdraw() 的区别在于关联了一个 ticket_id,一个 ticket_id 表示的操作至多只会被处理一次,每次调用都将返回第一次调用时的处理结果。这样,idempotent_withdraw 就符合幂等性了,客户端就可以放心地多次调用。

基于幂等性的解决方案中一个完整的取钱流程被分解成了两个步骤:

  1. 调用create_ticket() 获取ticket_id;
  2. 调用 idempotent_withdraw(ticket_id, account_id, amount)

虽然 create_ticket 不是幂等的,但在这种设计下,它对系统状态的影响可以忽略,加上 idempotent_withdraw 是幂等的,所以任何一步由于网络等原因失败或超时,客户端都可以重试,直到获得结果。如图2所示:

幂等设计

HTTP幂等

POST 不具有幂等性,PUT 具有幂等性

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 如果要追根溯源,幂等性是数学中的一个概念,表达的是N次变换与1次变换的结果相同。 基于HTTP协议的Web API...
    Ray雷磊阅读 5,840评论 0 1
  • 理解HTTP幂等性 基于HTTP协议的Web API是时下最为流行的一种分布式服务提供方式。无论是在大型互联网应用...
    阿灯_supwinr阅读 3,153评论 0 0
  • 转载自 Programming.log - a place to keep my thoughts on prog...
    厨子阅读 3,021评论 0 4
  • 本文转自:Todd Wei 理解HTTP幂等性基于HTTP协议的Web API是时下最为流行的一种分布式服务提供方...
    i云哲阅读 5,685评论 0 6
  • Restful REST全称是Representational State Transfer(表征性状态转移),适...
    李霖弢阅读 5,017评论 0 0