您好,登錄后才能下訂單哦!
本篇內容介紹了“java冪等性是什么”的有關知識,在實際案例的操作過程中,不少人都會遇到這樣的困境,接下來就讓小編帶領大家學習一下如何處理這些情況吧!希望大家仔細閱讀,能夠學有所成!
一般在服務調用時,讀服務如果調用失敗了,會自動按配置次數轉移到別的服務上去請求。而寫服務就不能重復請求,如果因為超時或者網絡故障等原因被調用服務并沒有返回成功的響應,服務調用方就認為是失敗了,但很有可能的是已經成功了,如果繼續重復請求寫服務,如轉賬類的服務,可能會造成嚴重的后果。所以,寫服務失敗不能設計成繼續發重復請求,被調用服務也要設計冪等性,即使重復請求,也不會造成影響。
知道上面的背景,所以,冪等性就是同樣的參數,重復請求相同的服務,必須得到相同的結果。
舉一個支付的場景,請求一個第三方支付接口發起支付功能,同樣的訂單號,同樣的金額信息,返回的都是成功。同樣的訂單號,不同的金額信息,返回的是訂單號重復。這就是冪等性設計,第三方支付效驗了請求參數和已有數據庫的信息一致時直接返回已有的成功數據,如果數據不一致而又訂單號重復直接報訂單號重復。而如果不做冪等性設計,同樣的訂單號,同樣的金額信息,重復支付,可能會造成金額累加。為了服務友好性,同樣的訂單號同樣的金額信息返回訂單號重復也是不友好的。
有些服務天生就具有冪等性,如修改用戶郵箱、性別等,不管你重復請求修改多少次,返回的結果都是一樣的。
所以,對于服務冪等性設計的要點就是一定要效驗請求參數有效性,及已有數據的對比。如果同樣的請求參數已經處理過就不要重復處理,直接返回,這就是冪等性核心點。
下面這張圖已經很形式的說明了冪等性的重要性。
“java冪等性是什么”的內容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業相關的知識可以關注億速云網站,小編將為大家輸出更多高質量的實用文章!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。