樂觀鎖 悲觀鎖及memcached實現方案

2021-07-10 06:04:07 字數 481 閱讀 6671

樂觀鎖與悲觀鎖的定義不再贅述,簡單說一下我的理解。

假定不會出現併發問題,只有更新資料時才檢查資料是否被鎖定。

假定會出現併發問題,讀取資料時即將資料鎖定。

先假定乙個場景:商品搶購。有n件商品,商品剩餘數量存在memcached裡,乙個搶購的請求過來,商品剩餘數量需減1,直到0。

讀取商品剩餘數量,並獲取token,如果剩餘數量為0,則退出

商品剩餘數量減1

檢查token並更新商品剩餘數量

如果[3]失敗,回到[1]

以上方案保證在高併發的場景下,同一時刻只有乙個客戶端可以搶購成功。

場景:審批流表單提交,兩個客戶端同時提交表單,欲將審批流從a狀態更新到b狀態。

檢查待審批資料是否被鎖定,是則退出

讀取待審批資料,並在memcached中設定鎖定標誌

更新審批資料

刪除鎖定標誌

以上方案可以保證同一時間,只有乙個客戶端能夠更改審批流狀態。

悲觀鎖樂觀鎖

1 悲觀鎖,正如其名,它指的是對資料被外界 包括本系統當前的其他事務,以及來自外部系統的事務處理 修改持保守態度,因此,在整個資料處理過程中,將資料處於鎖定狀態。悲觀鎖的實現,往往依靠資料庫提供的鎖機制 也只有資料庫層提供的鎖機制才能真正保證資料訪問的排他性,否則,即使在本系統中實現了加鎖機制,也無...

樂觀鎖 悲觀鎖

悲觀鎖 pessimistic lock 顧名思義,就是很悲觀,每次去拿資料的時候都認為別人會修改,所以每次在拿資料的時候都會上鎖,這樣別人想拿這個資料就會block直到它拿到鎖。傳統的關係型資料庫裡邊就用到了很多這種鎖機制,比如行鎖,表鎖等,讀鎖,寫鎖等,都是在做操作之前先上鎖。樂觀鎖 optim...

樂觀鎖 悲觀鎖

樂觀鎖 悲觀鎖 悲觀鎖 pessimistic locking 悲觀鎖,正如其名,它指的是對資料被外界 包括本系統當前的其他事務,以及來自外部系統的事務處理 修改持保守態度,因此,在整個資料處理過程中,將資料處於鎖定狀態。悲觀鎖的實現,往往依靠資料庫提供的鎖機制 也只有資料庫層提供的鎖機制才能真正保...