什么是服务的幂等?为什么要实现幂等?
目錄
什么是冪等?
讀和寫請求都需要做冪等嗎?
系統的哪部分需要做冪等?
數據訪問層的增刪改查都需要做冪等處理嗎?
數據庫的修改做冪等(age++的情況展開討論)
分布式系統的ID如何生成?
什么是冪等?
系統中的重復操作,不管執行多少次,都產生一樣的效果,或返回一樣的結果。
讀和寫請求都需要做冪等嗎?
讀請求不需要做冪等(因為讀請求不會對數據發生改變)。
寫請求需要做冪等(對數據發生改變了就根據需要做冪等)。
系統的哪部分需要做冪等?
因為數據訪問層和數據庫直接聯系,涉及到數據的增刪改查,所以需要在數據訪問層做冪等處理。
數據訪問層的增刪改查都需要做冪等處理嗎?
數據訪問層的增刪改查:
? ? 增:主鍵分業務主鍵(唯一)、自增主鍵(最好不用,自增主鍵不好做冪等)。如果是唯一主鍵,那么就是天然冪等(重復插入會報錯)。
? ? 讀:不會改變數據,所以不需要做冪等處理。
? ? 改:set?age=18或set?age++,age++不能保證冪等(主要討論這種情況)。
? ? 刪:where?uid=58或者where?uid?in?bottom 10。刪除最后10條,不冪等(不推薦這種做法)。推薦根據id刪除,這樣不管刪除多少次結果都是一樣的。
數據庫的修改做冪等(age++的情況展開討論)
這種情況,一般都是先查詢,再進行修改,例如:update db set age++?where age=18 (偽代碼)
或者將相對值改為絕對值的修改:set?age=19
?
修改做冪等通常伴隨著分布式事務的問題:
例如銀行轉賬,A給B轉賬500元,這種就需要做冪等處理。(這里涉及到分布式事務,以后再寫一篇文章專門介紹分布式事務)
通常的轉賬流程:
1.A發起轉賬500的請求,生成流水號。
2.A賬戶凍結500元,該單號狀態設置為正在轉賬的狀態。
3.B帳號增加500元,該單號狀態設置為轉賬成功狀態。
數據庫的冪等也可以用分布式鎖來進行處理。
分布式系統的ID如何生成?
這里推薦一個Twitter用的snowflake來生成分布式系統的ID。
與50位技術專家面對面20年技術見證,附贈技術全景圖總結
以上是生活随笔為你收集整理的什么是服务的幂等?为什么要实现幂等?的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: springboot集成restTemp
- 下一篇: 什么是分布式锁?redis、zookee