天天看點

服務高可用:幂等性設計

什麼是幂等性?

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

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

幂等性設計

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

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

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