redisson看門狗實現原理

Redisson 看門狗(Watch Dog)機制實現原理

Redisson 的?Watch Dog?機制是分布式鎖的核心組件之一,用于?自動續期?鎖的過期時間,防止業務邏輯執行時間超過鎖的持有時間,導致鎖提前釋放而引發并發問題。以下是其實現原理的詳細分析:


1. 看門狗的核心作用

  • 問題背景
    當線程獲取鎖后,如果業務執行時間超過鎖的過期時間(如設置的?leaseTime=30s),鎖可能會被其他線程獲取,導致數據不一致。

  • 解決方案
    Watch Dog 會?定期檢查?并?自動延長鎖的過期時間,確保業務執行完成前鎖不會失效。


2. 看門狗的工作流程

(1)加鎖時啟動看門狗

當使用?tryLock()?或?lock()?方法獲取鎖時:

  • 如果?不指定?leaseTime(即鎖無固定過期時間),Redisson 會?自動啟動 Watch Dog

  • 如果?指定?leaseTime(如?lock.lock(10, TimeUnit.SECONDS)),則?不會啟動 Watch Dog(由業務自行控制鎖的釋放)。

關鍵代碼(RedissonLock.class)

java

復制

下載

// 如果未指定 leaseTime,則啟動 Watch Dog
if (leaseTime == -1) {// 設置默認過期時間(30秒)internalLockLeaseTime = lockWatchdogTimeout;// 啟動 Watch DogscheduleExpirationRenewal(threadId);
}

(2)Watch Dog 的續期邏輯

Watch Dog 本質上是一個?后臺定時任務,默認每?10 秒?檢查一次鎖的狀態,并重置鎖的過期時間(續期至 30 秒)。

續期任務(renewExpiration()

java

復制

下載

protected void renewExpiration() {// 1. 獲取當前線程的鎖信息ExpirationEntry entry = EXPIRATION_RENEWAL_MAP.get(getEntryName());if (entry == null) {return;}// 2. 創建定時任務,每 10 秒執行一次Timeout task = commandExecutor.getConnectionManager().newTimeout(new TimerTask() {@Overridepublic void run(Timeout timeout) {// 3. 檢查鎖是否仍被當前線程持有if (EXPIRATION_RENEWAL_MAP.containsKey(getEntryName())) {// 4. 執行 Lua 腳本,延長鎖的過期時間RFuture<Boolean> future = renewExpirationAsync(threadId);future.onComplete((res, e) -> {if (e != null) {log.error("Can't update lock expiration", e);return;}if (res) {// 5. 遞歸調用,繼續續期renewExpiration();}});}}}, lockWatchdogTimeout / 3, TimeUnit.MILLISECONDS); // 默認 10 秒(30s / 3)entry.setTimeout(task);
}
Lua 續期腳本

lua

復制

下載

-- KEYS[1]: 鎖的 Key
-- ARGV[1]: 過期時間(30s)
-- ARGV[2]: 客戶端唯一標識(UUID + 線程ID)-- 1. 檢查鎖是否仍由當前線程持有
if (redis.call('hexists', KEYS[1], ARGV[2]) == 1) then-- 2. 延長鎖的過期時間redis.call('pexpire', KEYS[1], ARGV[1]);return 1;
end;
return 0;

(3)釋放鎖時關閉 Watch Dog

當調用?unlock()?時,Redisson 會?清理 Watch Dog 任務,避免不必要的續期。

關鍵代碼

java

復制

下載

@Override
public void unlock() {try {// 1. 釋放鎖get(unlockAsync(Thread.currentThread().getId()));} finally {// 2. 取消 Watch Dog 任務cancelExpirationRenewal(Thread.currentThread().getId());}
}

3. 關鍵配置參數

參數默認值說明
lockWatchdogTimeout30,000 ms鎖的默認過期時間(未指定?leaseTime?時生效)
續期間隔10,000 msWatch Dog 的檢查間隔(lockWatchdogTimeout / 3
leaseTime-1如果手動指定(如?lock.lock(10, TimeUnit.SECONDS)),則?不啟動 Watch Dog

4. 看門狗的適用場景

(1)適合使用 Watch Dog 的情況

  • 業務執行時間不確定(如網絡請求、復雜計算)。

  • 需要防止鎖意外過期(如 GC 停頓導致業務阻塞)。

(2)不適合使用 Watch Dog 的情況

  • 能明確預估業務時間(如?leaseTime=10s,業務肯定在 5s 內完成)。

  • 對鎖的持有時間敏感(如嚴格要求鎖 10s 后必須釋放)。


5. 與其他方案的對比

機制Redisson Watch DogSETEX + 自旋重試Zookeeper 臨時節點
自動續期? 后臺線程定時續期? 需業務代碼控制? 依賴 Session 超時
鎖安全性高(Lua 腳本原子操作)中(依賴業務代碼正確性)高(CP 系統保證)
適用場景高并發、業務時間不確定簡單場景、短任務強一致性要求嚴格的場景

6. 最佳實踐

  1. 推薦使用默認 Watch Dog(不指定?leaseTime),避免鎖提前釋放。

  2. 避免濫用鎖:鎖的粒度要小(如?lock:order:1001?而非?lock:order)。

  3. 監控 Watch Dog:如果發現續期失敗,可能是 Redis 連接問題或鎖被強制刪除。


總結

Redisson 的?Watch Dog 機制?通過?后臺定時任務 + Lua 腳本續期,解決了分布式鎖在長業務場景下的?自動保活問題,是生產環境高可用分布式鎖的核心保障。

開啟新對話

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/diannao/89163.shtml
繁體地址,請注明出處:http://hk.pswp.cn/diannao/89163.shtml
英文地址,請注明出處:http://en.pswp.cn/diannao/89163.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

C++中explicit詳解

文章目錄 1. **防止隱式類型轉換**示例1&#xff1a;沒有使用explicit示例2&#xff1a;使用explicit 2. **防止拷貝初始化**示例1&#xff1a;沒有使用explicit示例2&#xff1a;使用explicit 3. **防止隱式類型轉換的鏈式調用**示例1&#xff1a;沒有使用explicit示例2&#…

代碼部落 20250629 CSP-J復賽 模擬賽

網址&#xff1a;代碼部落 一&#xff1a; 相濡以沫 β&#xff08;代碼請自寫&#xff09; 簽到題&#xff0c;如果a[i]<a[i1] a[i]a[i1],反之&#xff0c;直接輸出No 二 共同富裕&#xff08;代碼請自寫&#xff09; 簽到題&#xff0c;用sort前綴和 如果最富有的個…

零基礎學習RabbitMQ(5)--工作模式(1)

在前面的章節中我們簡單介紹過一些RabbitMQ的工作模式&#xff0c;RabbitMQ共提供了七種工作模式進行消息傳遞&#xff0c;這里我們來詳細介紹。 1. Simple(簡單模式) P&#xff1a;生產者 C&#xff1a;消費者 特點&#xff1a;一個生產者一個消費者&#xff0c;消息只能被…

Android Liunx ffmpeg交叉編譯

本文的交叉編譯在window上安裝VMware&#xff0c;使用Ubuntu20.4進行的編譯。 一、安裝NDK&#xff1a; 1、下載解壓&#xff1a; 在NDK 下載 | Android NDK | Android Developers下載Liunx平臺的NDK。 本人下載的是android-ndk-r27c-linux.zip版本的。 解壓android-ndk-r…

極海G32R501雙向數字電源解決方案 賦能AI服務器及電源應用創新

6月26日&#xff0c;Big-Bit商務網主辦的2025中國電子熱點解決方案創新峰會在東莞召開&#xff0c;峰會以“核心智變、能效躍遷”為主題&#xff0c;聚焦光儲充、800V超充、AI服務器、BMS、智能汽車照明與汽車中小電機電控應用。 峰會期間&#xff0c;珠海極海半導體有限公司&a…

【修電腦的小記錄】連不上網

問題概述 問題表現為&#xff1a;電腦連接網絡后&#xff0c;顯示已連接但無法上網。 環境信息&#xff1a; - DNS 修改無效&#xff0c;ping 外網&#xff08;8.8.8.8&#xff09;失敗 - 嘗試重置網絡參數、多種命令無果 &#x1f50d; 排查過程 1. 執行以下命令重置網絡&a…

QT中QSS樣式表的詳細介紹

轉自個人博客 **Qt樣式表&#xff08;Qt Style Sheets&#xff0c;簡稱QSS&#xff09;**是一種類似于HTML中的CSS&#xff08;層疊樣式表&#xff09;的機制&#xff0c;用于自定義Qt應用程序的外觀。通過QSS&#xff0c;開發者可以輕松地修改控件的外觀&#xff0c;而無需更改…

Spring 依賴注入:官方推薦方式及最佳實踐

Spring 依賴注入&#xff1a;官方推薦方式及最佳實踐 你正在遭遇以下困境嗎&#xff1f; 項目變大后&#xff0c;依賴關系像一團亂麻&#xff0c;牽一發而動全身&#xff1f;單元測試難如登天&#xff0c;被迫啟動整個Spring容器&#xff1f;NullPointerException 總在運行時突…

javaweb聽課筆記day1

MySQL數據模型 關系型數據庫: 通過表來存儲數據 關系型數據庫是建立在關系模型基礎上的數據庫&#xff0c;簡單說&#xff0c;關系型數據庫是由多張能互相連接的二維表組成的數據庫 優點: 都是使用表結構&#xff0c;格式一致&#xff0c;易于維護;使用通用的SQL語言操作…

《從量子奇境到前端優化:解鎖卡西米爾效應的隱藏力量》

卡西米爾效應由荷蘭物理學家亨德里克卡西米爾于1948年提出&#xff0c;它源于量子場論中“真空不空”的奇異觀點。在傳統認知里&#xff0c;真空是一片虛無&#xff0c;但量子理論指出&#xff0c;真空中充滿了持續漲落的能量&#xff0c;即零點能。想象有兩片中性的金屬板被放…

【學習筆記】強化學習的數學原理

軟活硬整&#xff0c;納什又把RL翻出來講了一遍&#xff0c;我以為是溫故而知新&#xff0c;原來是在賣書。 不過溫故而知新還是沒啥毛病的。 PS&#xff1a;今天裝Notepad時看到的&#xff0c;我還以為現在連用個Notepad都要給天線寶寶們捐款了。 文章目錄 PART 11 overview…

深入“火星棒球數據API”:用數據解鎖棒球世界的無限可能

在棒球運動日益數據化的今天&#xff0c;高效獲取和處理海量比賽信息已成為球隊制勝、媒體解讀、球迷深入理解比賽的關鍵。“火星棒球數據API” 應運而生&#xff0c;成為連接棒球智慧與大數據技術的橋梁。本文將探討這一API的核心價值、功能亮點及其如何重塑我們體驗和分析棒球…

[附源碼+數據庫+畢業論文]基于Spring+MyBatis+MySQL+Maven+jsp實現的校園服務平臺管理系統,推薦!

摘 要 現代經濟快節奏發展以及不斷完善升級的信息化技術&#xff0c;讓傳統數據信息的管理升級為軟件存儲&#xff0c;歸納&#xff0c;集中處理數據信息的管理方式。本校園服務平臺管理系統就是在這樣的大環境下誕生&#xff0c;其可以幫助管理者在短時間內處理完畢龐大的數據…

「Java EE開發指南」如何用MyEclipse創建一個WEB項目?(三)

在本文中&#xff0c;您可以找到有關WEB項目的信息。將了解&#xff1a; Web項目結構和參數Web開發生產力工具JSP代碼完成和驗證 這些特性在MyEclipse中可用。在上文中&#xff08;點擊這里回顧>>&#xff09;&#xff0c;我們為大家介紹了Web開發效率工具、Web項目參數…

笨方法學python -練習6

程序&#xff1a; print("Mary had a little lamb.") print("Its fleece was white as {}.".format(snow)) print("And everywhere that Mary went.") print("." * 10) # what′d that do? end1 "C" end2 "h&qu…

【MySQL】Binlog文件占用空間比較大,如何清理

一、前言 在進行一次數據導入之后&#xff0c;發現服務器磁盤爆滿&#xff0c;初步判斷是數據庫產生了大量binlog所致&#xff0c;接下來進行分析處理。 二、分析 1、查看磁盤空間 通過df -h命令&#xff0c;查看磁盤空間占用情況 2、查找占用文件或目錄 通過命令&#xff1a;…

車載診斷架構 --- 非易失性存儲器(NVM)相關設置項

我是穿拖鞋的漢子,魔都中堅持長期主義的汽車電子工程師。 老規矩,分享一段喜歡的文字,避免自己成為高知識低文化的工程師: 做到欲望極簡,了解自己的真實欲望,不受外在潮流的影響,不盲從,不跟風。把自己的精力全部用在自己。一是去掉多余,凡事找規律,基礎是誠信;二是…

C#: 輸入對話框窗口函數

這是一個 C# 輸入對話框函數&#xff0c;主要功能包括&#xff1a; 基礎功能&#xff1a;創建帶標題、提示文本和輸入框的對話框&#xff0c;返回用戶輸入或空字符串&#xff08;取消時&#xff09; 增強特性&#xff1a; 支持必填項驗證支持正則表達式格式驗證實時錯誤提示與…

PCB工藝學習與總結-20250628

一、PCB板材 1、結構組成 基板:作為電路板的支撐體,通常由絕緣材料制成,如玻璃纖維或塑料。 導線:用于連接電路板上的各個元件,傳輸電流和信號。 元件:包括電阻、電容、電感、二極管、晶體管等,用于實現電路的各種功能。 焊盤:用于焊接元件引腳的金屬片,確保元件…

VUE2與VUE3項目環境變量創建與使用區別

環境變量文件是項目中的.env開頭的文件&#xff0c;如下圖&#xff1a; 下圖是VUE2.env文件中的配置&#xff0c;是以VUE_APP開頭的 VUE_APP_PAGE_TITLE系統 VUE_APP_SERVICE_PREFIX/gateway/xxxxx在使用時 只需要 調用 process.env.VUE_APP_SERVICE_PREFIX 就可以獲取到值 而…