精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

面試問Redis鎖,我臉都綠了......

運維 數據庫運維 Redis
筆者今天帶來一篇關于 Redis 鎖的文章,連敲帶畫碼出此文,有一些細節,對 Redis 鎖不清晰的盆友不妨瞧一瞧。

筆者今天帶來一篇關于 Redis 鎖的文章,連敲帶畫碼出此文,有一些細節,對 Redis 鎖不清晰的盆友不妨瞧一瞧。

如果是有經驗的盆友,挑挑毛病,那筆者是更感謝了!閑話不多,馬上發車。

談起 Redis 鎖,下面三個,算是出現最多的高頻詞匯:

  •  Setnx
  •  RedLock
  •  Redisson

Setnx

目前通常所說的 Setnx 命令,并非單指 Redis 的 setnx key value 這條命令。

一般代指 Redis 中對 Set 命令加上 NX 參數進行使用,Set 這個命令,目前已經支持這么多參數可選: 

  1. SET key value [EX seconds|PX milliseconds] [NX|XX] [KEEPTTL] 

當然了,就不在文章中默寫 API 了,基礎參數還有不清晰的,可以蹦到官網。

上圖是筆者畫的 Setnx 大致原理,主要依托了它的 Key 不存在才能 Set 成功的特性,進程 A 拿到鎖,在沒有刪除鎖的 Key 時,進程 B 自然獲取鎖就失敗了。

那么為什么要使用 PX 30000 去設置一個超時時間?是怕進程 A 不講道理啊,鎖沒等釋放呢,萬一崩了,直接原地把鎖帶走了,導致系統中誰也拿不到鎖。

[[320178]]

就算這樣,還是不能保證萬無一失。如果進程 A 又不講道理,操作鎖內資源超過筆者設置的超時時間,那么就會導致其他進程拿到鎖,等進程 A 回來了,回手就是把其他進程的鎖刪了,如圖:

還是剛才那張圖,將 T5 時刻改成了鎖超時,被 Redis 釋放。

進程 B 在 T6 開開心心拿到鎖不到一會,進程 A 操作完成,回手一個 Del,就把鎖釋放了。

當進程 B 操作完成,去釋放鎖的時候(圖中 T8 時刻):

[[320179]]

找不到鎖其實還算好的,萬一 T7 時刻有個進程 C 過來加鎖成功,那么進程 B 就把進程 C 的鎖釋放了。

以此類推,進程 C 可能釋放進程 D 的鎖,進程 D....(禁止套娃),具體什么后果就不得而知了。

所以在用 Setnx 的時候,Key 雖然是主要作用,但是 Value 也不能閑著,可以設置一個唯一的客戶端 ID,或者用 UUID 這種隨機數。

當解鎖的時候,先獲取 Value 判斷是否是當前進程加的鎖,再去刪除。偽代碼: 

  1. String uuid = xxxx 
  2. // 偽代碼,具體實現看項目中用的連接工具  
  3. // 有的提供的方法名為set 有的叫setIfAbsent  
  4. set Test uuid NX PX 3000  
  5. try{  
  6. // biz handle....  
  7. } finally {  
  8.     // unlock  
  9.     if(uuid.equals(redisTool.get('Test')){  
  10.         redisTool.del('Test');  
  11.     }  

這回看起來是不是穩了?相反,這回的問題更明顯了,在 Finally 代碼塊中,Get 和 Del 并非原子操作,還是有進程安全問題。

[[320180]]

為什么有問題還說這么多呢?有如下兩點原因:

  •  搞清劣勢所在,才能更好的完善。
  •  上文中最后這段代碼,還是有很多公司在用的。

大小項目悖論:

大公司實現規范,但是小司小項目雖然存在不嚴謹,可并發倒也不高,出問題的概率和大公司一樣低。

[[320181]]

那么刪除鎖的正確姿勢之一,就是可以使用 Lua 腳本,通過 Redis 的 eval/evalsha 命令來運行: 

  1. -- lua刪除鎖:  
  2. -- KEYS和ARGV分別是以集合方式傳入的參數,對應上文的Test和uuid。  
  3. -- 如果對應的value等于傳入的uuid。 
  4.  if redis.call('get', KEYS[1]) == ARGV[1]   
  5.     then   
  6.     -- 執行刪除操作  
  7.         return redis.call('del', KEYS[1])   
  8.     else   
  9.     -- 不成功,返回0  
  10.         return 0   
  11. end 

通過 Lua 腳本能保證原子性的原因說的通俗一點:就算你在 Lua 里寫出花,執行也是一個命令(eval/evalsha)去執行的,一條命令沒執行完,其他客戶端是看不到的。

那么既然這么麻煩,有沒有比較好的工具呢?就要說到 Redisson 了。

介紹 Redisson 之前,筆者簡單解釋一下為什么現在的 Setnx 默認是指 Set 命令帶上 NX 參數,而不是直接說是 Setnx 這個命令。

因為 Redis 版本在 2.6.12 之前,Set 是不支持 NX 參數的,如果想要完成一個鎖,那么需要兩條命令: 

  1. 1. setnx Test uuid  
  2. 2. expire Test 30 

即放入 Key 和設置有效期,是分開的兩步,理論上會出現 1 剛執行完,程序掛掉,無法保證原子性。

但是早在 2013 年,也就是 7 年前,Redis 就發布了 2.6.12 版本,并且官網(Set 命令頁),也早早就說明了“SETNX,SETEX,PSETEX 可能在未來的版本中,會棄用并永久刪除”。

筆者曾閱讀過一位大佬的文章,其中就有一句指導入門者的面試小套路,具體文字忘記了,大概意思如下:說到 Redis 鎖的時候,可以先從 Setnx 講起,最后慢慢引出 Set 命令的可以加參數,可以體現出自己的知識面。

如果有緣你也閱讀過這篇文章,并且學到了這個套路,作為本文的筆者我要加一句提醒:請注意你的工作年限!首先回答官網表明即將廢棄的命令,再引出 Set 命令七年前的“新特性”,如果是剛畢業不久的人這么說,面試官會以為自己穿越了。

你套路面試官,面試官也會套路你。  

-- vt・沃茲基碩德

Redisson

Redisson 是 Java 的 Redis 客戶端之一,提供了一些 API 方便操作 Redis。

但是 Redisson 這個客戶端可有點厲害,筆者在官網截了僅僅是一部分的圖:

這個特性列表可以說是太多了,是不是還看到了一些 JUC 包下面的類名,Redisson 幫我們搞了分布式的版本。

比如 AtomicLong,直接用 RedissonAtomicLong 就行了,連類名都不用去新記,很人性化了。

鎖只是它的冰山一角,并且從它的 Wiki 頁面看到,對主從,哨兵,集群等模式都支持,當然了,單節點模式肯定是支持的。

本文還是以鎖為主,其他的不過多介紹。Redisson 普通的鎖實現源碼主要是 RedissonLock 這個類,還沒有看過它源碼的盆友,不妨去瞧一瞧。

源碼中加鎖/釋放鎖操作都是用 Lua 腳本完成的,封裝的非常完善,開箱即用。

這里有個小細節,加鎖使用 Setnx 就能實現,也采用 Lua 腳本是不是多此一舉?

筆者也非常嚴謹的思考了一下:這么厲害的東西哪能寫廢代碼?

[[320182]]  

其實筆者仔細看了一下,加鎖解鎖的 Lua 腳本考慮的非常全面,其中就包括鎖的重入性,這點可以說是考慮非常周全,我也隨手寫了代碼測試一下:

的確用起來像 JDK 的 ReentrantLock 一樣絲滑,那么 Redisson 實現的已經這么完善,RedLock 又是什么?

RedLock

[[320183]]

RedLock的中文是直譯過來的,就叫紅鎖。紅鎖并非是一個工具,而是 Redis 官方提出的一種分布式鎖的算法。

就在剛剛介紹完的 Redisson 中,就實現了 RedLock 版本的鎖。也就是說除了 getLock 方法,還有 getRedLock 方法。

筆者大概畫了一下對紅鎖的理解:

如果你不熟悉 Redis 高可用部署,那么沒關系。RedLock 算法雖然是需要多個實例,但是這些實例都是獨自部署的,沒有主從關系。

RedLock 作者指出,之所以要用獨立的,是避免了 Redis 異步復制造成的鎖丟失,比如:主節點沒來的及把剛剛 Set 進來這條數據給從節點,就掛了。

有些人是不是覺得大佬們都是杠精啊,天天就想著極端情況。其實高可用嘛,拼的就是 99.999...% 中小數點后面的位數。

回到上面那張簡陋的圖片,紅鎖算法認為,只要 2N+1 個節點加鎖成功,那么就認為獲取了鎖, 解鎖時將所有實例解鎖。

流程為:

  •  順序向五個節點請求加鎖
  •  根據一定的超時時間來推斷是不是跳過該節點
  •  三個節點加鎖成功并且花費時間小于鎖的有效期
  •  認定加鎖成功

也就是說,假設鎖 30 秒過期,三個節點加鎖花了 31 秒,自然是加鎖失敗了。

這只是舉個例子,實際上并不應該等每個節點那么長時間,就像官網所說的那樣,假設有效期是 10 秒,那么單個 Redis 實例操作超時時間,應該在 5 到 50 毫秒(注意時間單位)。

還是假設我們設置有效期是 30 秒,圖中超時了兩個 Redis 節點。那么加鎖成功的節點總共花費了 3 秒,所以鎖的實際有效期是小于 27 秒的。

即扣除加鎖成功三個實例的 3 秒,還要扣除等待超時 Redis 實例的總共時間。看到這,你有可能對這個算法有一些疑問,那么你不是一個人。

回頭看看 Redis 官網關于紅鎖的描述,就在這篇描述頁面的最下面,你能看到著名的關于紅鎖的神仙打架事件。

[[320184]]

即 Martin Kleppmann 和 Antirez 的 RedLock 辯論。一個是很有資歷的分布式架構師,一個是 Redis 之父。

官方掛人,最為致命。開個玩笑,要是質疑能被官方掛到官網,說明肯定是有價值的。

所以說如果項目里要使用紅鎖,除了紅鎖的介紹,不妨要多看兩篇文章,即:

  •  Martin Kleppmann 的質疑貼
  •  Antirez 的反擊貼

總結

看了這么多,是不是發現如何實現,都不能保證 100% 的穩定。程序就是這樣,沒有絕對的穩定,所以做好人工補償環節也是重要的一環,畢竟:技術不夠,人工來湊! 

 

責任編輯:龐桂玉 來源: 數據庫開發
相關推薦

2020-08-03 15:20:56

Redis數據庫命令

2024-07-01 00:00:02

2010-08-11 11:12:46

IT公司面試問題

2022-12-08 17:15:54

Java并發包

2019-04-28 11:48:54

Python面試工程師

2022-07-06 08:01:05

數據庫分布式

2018-07-25 14:27:43

Redis數據架構存儲

2018-09-05 12:20:09

數據庫Redis面試題

2022-11-09 17:10:47

JVM內存區域

2020-06-17 08:53:19

Redis集群SSH

2020-12-18 08:28:13

Redis數據數據庫

2019-05-07 18:17:26

Redis服務器數據

2024-08-12 09:55:42

Redis二進制數據

2013-10-22 10:17:17

2013-11-01 09:27:48

Twitter技術面試

2022-11-26 17:54:05

2020-12-01 11:50:49

數據庫Redis面試

2025-03-17 07:46:41

2019-04-09 09:22:32

Redis內存緩存

2022-02-23 22:01:23

SpringAOP模式
點贊
收藏

51CTO技術棧公眾號

欧美一区二区高清| 亚洲精品中文字幕乱码三区| 欧美一区在线直播| 国产成人免费观看网站| 国产精品国产三级在线观看| 一区二区久久久久久| 久久久久九九九| 日本一区二区三区久久| 中文字幕一区二区av| 日韩电影免费观看在线观看| 九九热在线免费| 日本在线视频www鲁啊鲁| 91亚洲精品一区二区乱码| 国产精品久久久久av免费| 欧美片一区二区| 国产一区二区三区天码| 欧美一级一级性生活免费录像| 免费看又黄又无码的网站| 求av网址在线观看| www久久久久| 999久久久| 成人免费一区二区三区| 亚洲精品乱码久久久久久蜜桃麻豆| 国产亚洲精品激情久久| 久久久午夜精品福利内容| 四虎视频在线精品免费网址| 懂色av影视一区二区三区| 国产精品99久久久久久大便| 国内在线免费高清视频| 成人免费观看视频| 91在线视频九色| 最新黄色网址在线观看| 国产精品久久久久久久免费软件 | 亚洲无人区码一码二码三码的含义| 国产免费区一区二区三视频免费| 色拍拍在线精品视频8848| 日韩精品一区二区在线视频| 午夜视频在线观看网站| 久久久久久免费网| 国产精品一区二| 精品人妻无码一区二区| 狠狠色综合播放一区二区| 国产精品a久久久久久| 在线观看黄网站| 精品成人久久| 欧美激情精品久久久久久蜜臀| 九九热视频在线免费观看| 日韩精品欧美| 中文字幕在线观看亚洲| 久久久久久久久久久久| 亚洲毛片免费看| 亚洲欧美福利视频| 免费看污黄网站在线观看| 国产suv精品一区| 精品国产乱码久久久久久老虎 | 中文字幕永久免费视频| 日韩在线一区二区三区| 国产精品爱久久久久久久| 无码任你躁久久久久久久| 亚洲免费中文| 7777免费精品视频| av大片在线免费观看| 国产情侣久久| 日韩免费观看在线观看| 无码人妻久久一区二区三区不卡| 毛片一区二区| 国产精品视频成人| 91精品国产乱码久久久久| 精品一区二区三区影院在线午夜 | 国产精品99久久免费观看| 日韩一区二区电影在线| 美国黄色一级视频| 全国精品免费看| 亚洲精品在线观看www| 91成人在线免费视频| 成人毛片免费看| 视频直播国产精品| 久草国产在线观看| 免费看亚洲片| 国产日产欧美精品| 亚洲精品国产精| 久久久激情视频| 一区二区精品在线观看| 四虎亚洲成人| 精品久久久久久久久久| 国产又大又黄又粗的视频| 久久精品超碰| 精品美女一区二区三区| 扒开jk护士狂揉免费| 波多野结衣的一区二区三区| 久久久av免费| 六月丁香婷婷综合| 国内欧美视频一区二区| 激情小说网站亚洲综合网| 国产精品影院在线| 亚洲精品视频在线| 黄色a级片免费| 久久久精品区| 国产偷亚洲偷欧美偷精品| 99re6热在线精品视频| 好看的亚洲午夜视频在线| 国产成人aa精品一区在线播放| 一区二区三区www污污污网站| 国产成人亚洲综合a∨猫咪| 蜜桃传媒视频麻豆第一区免费观看| 国产精品一区二区婷婷| 亚洲国产精品久久艾草纯爱| 日本va中文字幕| av不卡一区| 伊人久久久久久久久久久| 久久久久久蜜桃| 奇米一区二区三区| 久久亚洲综合网| 中国av在线播放| 精品视频免费在线| 久久中文字幕人妻| 欧美午夜a级限制福利片| 国产精品成人久久久久| 色屁屁草草影院ccyycom| 国产精品不卡在线| 国产精品99久久免费黑人人妻| 亚洲视频一起| 久久精品国产69国产精品亚洲| 国产精品人人人人| 成人精品免费视频| 麻豆视频传媒入口| 欧美伊人亚洲伊人色综合动图| 精品亚洲一区二区三区在线观看 | 欧美色综合网站| 中文字幕在线播放视频| 在线精品视频在线观看高清| 国产精品毛片a∨一区二区三区|国| 欧美一区,二区| 亚洲日本一区二区| 最新天堂在线视频| 日韩免费久久| 国产99久久久欧美黑人| 五月婷婷免费视频| 精品国产91久久久久久| 69xxx免费视频| 亚洲91中文字幕无线码三区| 国产精品劲爆视频| 国产天堂在线| 色偷偷久久人人79超碰人人澡| 欧美一级片黄色| 亚洲久久成人| 国产一区在线免费观看| av影院在线免费观看| 欧美精品一区二区精品网| 国产精品白嫩白嫩大学美女| 国产毛片精品视频| 成年人深夜视频| a看欧美黄色女同性恋| 九九视频这里只有精品| 99免费在线视频| 一区二区三区欧美激情| 特种兵之深入敌后| 国产精品va| 精品产品国产在线不卡| 波多一区二区| 日韩电影在线观看中文字幕| 亚洲精品国产精品乱码| 91在线视频18| 久久久久狠狠高潮亚洲精品| 久久99精品久久久久久园产越南| 日韩免费观看网站| 香蕉视频网站在线观看| 91精品国产免费久久综合| 青青草手机在线观看| 成人在线综合网站| 日韩在线一级片| 国产成人三级| 91夜夜未满十八勿入爽爽影院 | 色男人天堂av| 亚洲天堂黄色| 欧美在线日韩精品| 日本黄色成人| 欧美精品www| 伦理片一区二区三区| 欧美日韩一区在线| 欧美成人手机视频| 91美女片黄在线观看91美女| 无码内射中文字幕岛国片| 99精品电影| 国产女人水真多18毛片18精品| 自拍在线观看| 久久天天躁狠狠躁夜夜躁| 欧美 日韩 综合| 欧美午夜视频网站| 久久免费视频6| 久久精品男人天堂av| 四虎成人在线播放| 午夜在线视频一区二区区别| 亚洲欧洲精品一区| 成人台湾亚洲精品一区二区| 日本亚洲欧洲色α| 色呦呦在线播放| 国产香蕉一区二区三区在线视频 | 国产性猛交╳xxx乱大交| 欧美激情中文不卡| 国产大尺度视频| 日本网站在线观看一区二区三区| 日本人妻伦在线中文字幕| 精品在线91| 97超碰资源| 日韩另类视频| 97碰碰碰免费色视频| 麻豆传媒视频在线观看免费| 日韩大片免费观看视频播放| 99riav国产| 在线视频你懂得一区| 久久精品国产亚洲av高清色欲 | 欧美人妻精品一区二区三区| 国产三级精品视频| 色婷婷免费视频| 国产精品自拍毛片| 丝袜制服一区二区三区| 99精品99| 免费人成自慰网站| 99热在线成人| 无码免费一区二区三区免费播放| 九九热hot精品视频在线播放| 成人a在线观看| 日产精品一区| 国产999精品久久久影片官网| 草草视频在线观看| 欧美精品生活片| 男人天堂久久久| 尤物yw午夜国产精品视频| 污视频网站在线播放| 日韩精品中文字幕一区二区三区 | 亚洲免费视频一区二区| 丰满人妻一区二区三区四区53| 91精品在线麻豆| 97超碰人人草| 欧美日韩不卡视频| 成人一级免费视频| 色婷婷综合激情| 久久久久99精品成人片我成大片 | 果冻天美麻豆一区二区国产| 亚洲va欧美va国产综合剧情| 欧美成人福利| 国产一区私人高清影院| 免费视频成人| 国产欧美精品一区二区三区-老狼| 大胆人体一区二区| 欧美一区视频在线| 日本久久免费| 国产精品久久久久久五月尺| 欧美人与性动交xxⅹxx| 日本欧美黄网站| 欧洲一级精品| 国产精品久久久久久久久免费 | 成人欧美视频在线| 综合视频一区| 精品日产一区2区三区黄免费 | 亚洲久久久久久久久久| 亚洲欧美日韩精品永久在线| 国产午夜精品久久久 | 久久精品99国产精品酒店日本| 色综合久久影院| 欧美成人午夜激情| 成年网站在线视频网站| 51色欧美片视频在线观看| 成人教育av| 国产精品天天狠天天看| 免费一级欧美片在线观看网站| 成人动漫视频在线观看免费| 狼人天天伊人久久| 欧美一级日本a级v片| 色婷婷色综合| 日本五级黄色片| 国产精品永久| 国产精品久久久毛片| 韩国av一区二区三区四区| 中文字幕在线视频播放| 久久综合av免费| 99久久99久久精品免费看小说.| 亚洲特黄一级片| 日韩欧美三级在线观看| 色天使色偷偷av一区二区| 91福利免费视频| 欧美一区二区日韩一区二区| 免费观看黄色av| 国产亚洲精品久久久| 91精品国产91久久久久久青草| 91精品国产91久久久久福利| 日韩av电影资源网| 99久久精品免费看国产一区二区三区 | 欧美四级电影网| 亚洲精品国偷拍自产在线观看蜜桃| 亚洲精品电影网在线观看| av在线天堂播放| 久久久久女教师免费一区| 肉色欧美久久久久久久免费看| 国产日韩欧美影视| 日韩精选在线| 亚洲一区 在线播放| 欧美资源在线| 亚洲丝袜在线观看| 国产色91在线| 日韩高清精品免费观看| 欧美日韩色一区| 手机av在线免费观看| 久久天天躁狠狠躁老女人| www.日韩| 成人精品一二区| 日韩影院二区| 18禁免费无码无遮挡不卡网站| 精品一区二区在线免费观看| 大地资源二中文在线影视观看| 中文字幕日韩av资源站| 欧美成人一区二区三区四区| 精品久久人人做人人爽| 色综合久久久久综合一本到桃花网| 欧美性做爰毛片| av综合网站| 真人做人试看60分钟免费| 蜜桃视频免费观看一区| 欧美 日本 国产| 亚洲国产美国国产综合一区二区| 中文字幕精品一区二| 日韩精品在线视频| 免费网站在线观看人| 亚洲www永久成人夜色| 欧美一区2区| 凹凸国产熟女精品视频| 成人性生交大片免费| 九九精品视频免费| 欧美三级电影一区| 成人在线观看免费| 98精品在线视频| 91在线一区| 国产 欧美 日本| 国产福利不卡视频| 永久免费看黄网站| 日韩一区和二区| 成人福利网站| 亚洲自拍在线观看| 欧美一区二区三区久久精品茉莉花| 亚洲视频第二页| 国产精品每日更新在线播放网址| 国产女主播喷水视频在线观看| 精品视频—区二区三区免费| 蜜桃麻豆影像在线观看| 精品国产乱码一区二区三区四区| 在线国产日韩| 亚洲色图14p| 狠狠色香婷婷久久亚洲精品| 天天摸夜夜添狠狠添婷婷| 国外成人在线视频| 啪啪国产精品| 久久国产成人精品国产成人亚洲| 93久久精品日日躁夜夜躁欧美| 国产黄色片免费看| 精品视频久久久久久久| 日韩精品一区二区三区av| 亚洲高清视频一区| 激情文学综合丁香| 免费中文字幕在线| 亚洲精品一区二区三区在线观看 | 日韩aaaaa| 午夜精品aaa| 免费在线视频你懂得| 国产精品精品视频| 91精品精品| 涩视频在线观看| 欧美日韩国产专区| 成人影院免费观看| 7777精品伊久久久大香线蕉语言| 狠狠综合久久av一区二区老牛| xxxxxx黄色| 欧美在线高清视频| 91黄色在线| 欧美日韩亚洲在线 | 91精品在线观| 影音先锋久久精品| 先锋影音av在线| 日韩一级片网址| 日本不良网站在线观看| 无遮挡亚洲一区| 成人一区二区三区| 在线观看亚洲黄色| 久久精品国产一区二区电影| 99久久香蕉| 欧美日韩亚洲自拍| 亚洲宅男天堂在线观看无病毒| 好男人免费精品视频| 91老司机在线| 亚洲女人av| 亚洲色偷偷综合亚洲av伊人| 亚洲国产美女久久久久| 久久天天久久| 成人免费观看cn| 欧美国产国产综合| 欧性猛交ⅹxxx乱大交| 国产精品视频永久免费播放| 欧美网站在线| 日本伦理一区二区三区| 亚洲韩国青草视频|