日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

什么是服务的幂等?为什么要实现幂等?

發布時間:2025/3/19 编程问答 20 豆豆
生活随笔 收集整理的這篇文章主要介紹了 什么是服务的幂等?为什么要实现幂等? 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

目錄

什么是冪等?

讀和寫請求都需要做冪等嗎?

系統的哪部分需要做冪等?

數據訪問層的增刪改查都需要做冪等處理嗎?

數據庫的修改做冪等(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年技術見證,附贈技術全景圖

總結

以上是生活随笔為你收集整理的什么是服务的幂等?为什么要实现幂等?的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。