<kbd id="afajh"><form id="afajh"></form></kbd>
<strong id="afajh"><dl id="afajh"></dl></strong>
    <del id="afajh"><form id="afajh"></form></del>
        1. <th id="afajh"><progress id="afajh"></progress></th>
          <b id="afajh"><abbr id="afajh"></abbr></b>
          <th id="afajh"><progress id="afajh"></progress></th>

          Redisson 分布式鎖源碼 07:公平鎖釋放

          共 1106字,需瀏覽 3分鐘

           ·

          2021-07-07 13:19

          前言

          看門狗機(jī)制是在 RedissonBaseLock#scheduleExpirationRenewal 方法中,這塊公平鎖和非公平鎖并無區(qū)別。

          前文已經(jīng)了解到,公平鎖加鎖失敗之后,會將當(dāng)前放到等待隊列中,通過 Java 代碼中的循環(huán)不斷嘗試獲得鎖。

          1

          鎖釋放

          主動釋放

          源碼:RedissonFairLock#unlockInnerAsync

          1. KEYS[1]:加鎖的名字,anyLock
          2. KEYS[2]:加鎖等待隊列,redisson_lock_queue:{anyLock}
          3. KEYS[3]:等待隊列中線程鎖時間的 set 集合,redisson_lock_timeout:{anyLock},是按照鎖的時間戳存放到集合中的;
          4. KEYS[4]:redisson_lock__channel:{anyLock}
          5. ARGV[1]:LockPubSub.UNLOCK_MESSAGE;
          6. ARGV[2]:鎖超時時間 30000;
          7. ARGV[3]:UUID:ThreadId 組合 58f6c4a2-9908-4957-b229-283a45359c4b:47
          8. ARGV[4]:currentTime 當(dāng)前時間戳。

          這塊邏輯突出部分已經(jīng)標(biāo)出,重點就是釋放鎖。

          1. 鎖在隊列中,超時了則直接從隊列中移除;
          2. 鎖減少重入次數(shù),減少后,如果重入次數(shù)大于 0,重置超時時間,如果不大于 0,則直接移除鎖。

          這樣的話后續(xù)就其他線程從等待隊列中開始獲得鎖。

          超時刪除

          在加鎖和釋放鎖的 lua 腳本中,第一段永遠(yuǎn)是一個 while true do xxx,作用就是用來移除隊列中超時的鎖。

          而持鎖線程的釋放,則和非公平鎖沒有任何區(qū)別,當(dāng)鎖超時或者服務(wù)宕機(jī),鎖就會被自動釋放。(這個是指 anyLock)。

          2

          總結(jié)

          公平鎖的釋放同樣分為主動釋放和超時釋放。

          1. 主動釋放,即自己調(diào)用釋放鎖。
          2. 超時刪除,則分為兩種,一種是持鎖線程超時刪除,這種和非公平鎖沒有任何區(qū)別,因為這個鎖也是含有超時時間+看門狗續(xù)租的。另一種則是等待隊列中的超時刪除,是在每次獲取鎖之前,判斷第一個等待線程的時間戳是否超時,從而移除鎖。


          - <End /> -




          歷史文章 | 相關(guān)推薦



          瀏覽 117
          點贊
          評論
          收藏
          分享

          手機(jī)掃一掃分享

          分享
          舉報
          評論
          圖片
          表情
          推薦
          點贊
          評論
          收藏
          分享

          手機(jī)掃一掃分享

          分享
          舉報
          <kbd id="afajh"><form id="afajh"></form></kbd>
          <strong id="afajh"><dl id="afajh"></dl></strong>
            <del id="afajh"><form id="afajh"></form></del>
                1. <th id="afajh"><progress id="afajh"></progress></th>
                  <b id="afajh"><abbr id="afajh"></abbr></b>
                  <th id="afajh"><progress id="afajh"></progress></th>
                  色逼视频国产 | 亚洲高清在线观看视频 | 免费观看黄色片 | 国产精品黄色电影 | 爱视频福利网 |