成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

Redis鎖被別人釋放怎么辦

數據庫 Redis 開發
客戶端在加鎖時,設置一個只有自己知道的唯一標識進去。例如,可以是自己的線程 ID,也可以是一個 UUID。

什么是分布式鎖?

要介紹分布式鎖,首先要提到與分布式鎖相對應的是線程鎖、進程鎖。

  • 線程鎖:主要用來給方法、代碼塊加鎖。當某個方法或代碼使用鎖,在同一時刻僅有一個線程執行該方法或該代碼段。線程鎖只在同一JVM中有效果,因為線程鎖的實現在根本上是依靠線程之間共享內存實現的,比如synchronized是共享對象頭,顯示鎖Lock是共享某個變量(state)。
  • 進程鎖:為了控制同一操作系統中多個進程訪問某個共享資源,因為進程具有獨立性,各個進程無法訪問其他進程的資源,因此無法通過synchronized等線程鎖實現進程鎖。

問題窺探

分布式鎖:當多個進程不在同一個系統中,用分布式鎖控制多個進程對資源的訪問。

有這樣一個情境,線程A和線程B都共享某個變量X。如果是分布式情況下,線程A和線程B很可能不是在同一對象中,每個客戶端在釋放鎖時,都是刪除操作,并沒有檢查這把鎖是否還是自己的,所以就會發生釋放別人鎖的風險。

解決辦法

客戶端在加鎖時,設置一個只有自己知道的唯一標識進去。例如,可以是自己的線程 ID,也可以是一個 UUID(隨機且唯一),這里我們以 UUID 舉例:

// 鎖的VALUE設置為UUID
127.0.0.1:6379> SET lock $uuid EX 20 NX
OK

這里假設 20s 操作共享時間完全足夠,先不考慮鎖自動過期的問題。之后,在釋放鎖時,要先判斷這把鎖是否還歸自己持有,偽代碼可以這么寫:

// 鎖是自己的,才釋放
if redis.get("lock") == $uuid:
    redis.del("lock")

這里釋放鎖使用的是 GET + DEL 兩條命令,這時,又會遇到我們前面講的原子性問題了。

  • 客戶端 1 執行 GET,判斷鎖是自己的
  • 客戶端 2 執行了 SET 命令,強制獲取到鎖(雖然發生概率比較低,但我們需要嚴謹地考慮鎖的安全性模型)
  • 客戶端 1 執行 DEL,卻釋放了客戶端 2 的鎖

由此可見,這兩個命令還是必須要原子執行才行。

怎樣原子執行呢?Lua 腳本。

我們可以把這個邏輯,寫成 Lua 腳本,讓 Redis 來執行。

因為 Redis 處理每一個請求是單線程執行的,在執行一個 Lua 腳本時,其它請求必須等待,直到這個 Lua 腳本處理完成,這樣一來,GET + DEL 之間就不會插入其它命令了。安全釋放鎖的 Lua 腳本如下:

// 判斷鎖是自己的,才釋放
if redis.call("GET",KEYS[1]) == ARGV[1]
then
    return redis.call("DEL",KEYS[1])
else
    return 0
end

好了,這樣一路優化,整個的加鎖、解鎖的流程就更嚴謹了。

這里我們先小結一下,基于 Redis 實現的分布式鎖,一個嚴謹的的流程如下:

加鎖:SET lock_key $unique_id EX $expire_time NX

操作共享資源 釋放鎖:Lua 腳本,先 GET 判斷鎖是否歸屬自己,再 DEL 釋放鎖。

責任編輯:趙寧寧 來源: 后端Q
相關推薦

2021-10-01 00:12:12

Redis分布式

2021-04-13 10:41:25

Redis內存數據庫

2019-10-12 09:50:46

Redis內存數據庫

2021-08-07 05:05:30

接口Redis項目

2011-06-30 17:58:30

網站被K

2020-07-10 08:46:26

HTTPS證書劫持網絡協議

2024-08-06 08:08:14

2024-10-09 17:06:52

RedisHash哈希表

2024-10-18 09:55:50

RedisHash數據

2015-03-31 15:33:55

2012-11-27 10:41:33

2022-08-24 08:17:14

RedisRDBAOF

2021-01-05 10:48:38

RedisAOF日志RDB快照

2011-06-27 15:42:23

降權SEO

2017-05-11 16:54:16

2015-10-28 17:09:13

技術創業

2017-12-08 11:14:21

2019-02-18 15:45:24

CPU頻率溫度

2021-01-26 08:02:04

Redis內存數據庫

2015-03-24 16:58:18

iPhone6
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 日本不卡一区 | 欧美成人精品激情在线观看 | a级网站| 久久亚洲一区二区三区四区 | 男女羞羞视频免费 | 亚洲性人人天天夜夜摸 | 国产日韩一区二区三区 | 成人精品一区二区三区中文字幕 | 欧美在线一区二区三区 | 亚洲女人的天堂 | 毛片站| 亚卅毛片 | 亚洲福利免费 | 伊人精品在线 | 久久精彩视频 | 国产成人免费 | 色视频成人在线观看免 | 黄色国产 | 成人在线视频一区 | 色在线免费视频 | 日韩在线视频免费观看 | 欧美成人免费在线 | 中文字幕电影在线观看 | 欧美一区二区三区在线观看视频 | 中文字幕 在线观看 | av国产精品毛片一区二区小说 | 欧美aaa一级片 | av网址在线 | 国产亚洲欧美日韩精品一区二区三区 | 精品国产三级 | 国产成人精品久久久 | 神马久久久久久久久久 | 久久国产欧美日韩精品 | 精品成人av| 91久久久久久久久久久 | 伊人热久久 | 久久久久久av | 久久人人爽人人爽人人片av免费 | 成av在线 | 天堂一区二区三区 | 国产高清免费视频 |