服務高可用:冪等性設計

作者:Java技術棧
鏈接:https://www.jianshu.com/p/0dbaa2a8b2e8

什麼是冪等性?

一般在服務調用時,讀服務如果調用失敗了,會自動按配置次數轉移到別的服務上去請求。而寫服務就不能重複請求,如果因為超時或者網絡故障等原因被調用服務並沒有返回成功的響應,服務調用方就認為是失敗了,但很有可能的是已經成功了,如果繼續重複請求寫服務,如轉賬類的服務,可能會造成嚴重的後果。所以,寫服務失敗不能設計成繼續發重複請求,被調用服務也要設計冪等性,即使重複請求,也不會造成影響。

知道上面的背景,所以,冪等性就是同樣的參數,重複請求相同的服務,必須得到相同的結果。

冪等性設計

舉一個支付的場景,請求一個第三方支付接口發起支付功能,同樣的訂單號,同樣的金額信息,返回的都是成功。同樣的訂單號,不同的金額信息,返回的是訂單號重複。這就是冪等性設計,第三方支付效驗了請求參數和已有數據庫的信息一致時直接返回已有的成功數據,如果數據不一致而又訂單號重複直接報訂單號重複。而如果不做冪等性設計,同樣的訂單號,同樣的金額信息,重複支付,可能會造成金額累加。為了服務友好性,同樣的訂單號同樣的金額信息返回訂單號重複也是不友好的。

有些服務天生就具有冪等性,如修改用戶郵箱、性別等,不管你重複請求修改多少次,返回的結果都是一樣的。

所以,對於服務冪等性設計的要點就是一定要效驗請求參數有效性,及已有數據的對比。如果同樣的請求參數已經處理過就不要重複處理,直接返回,這就是冪等性核心點。

下面這張圖已經很形式的說明了冪等性的重要性。

服務高可用:冪等性設計


分享到:


相關文章: