Redisson 看門狗機制

何為看門狗

看門狗機制的主要作用是自動續期鎖,確保在節點完成任務之前,鎖不會過期。具體來說,當一個節點獲取到鎖后,看門狗會定期檢查該鎖的過期時間,并在必要時延長鎖的過期時間,確保節點可以順利完成任務。

步驟

  1. 在獲取鎖的時候,不能指定leaseTime或者只能將leaseTime設置為-1,這樣才能開啟看門狗機制。
  2. 在tryLockInnerAsync方法里嘗試獲取鎖,如果獲取鎖成功調用scheduleExpirationRenewal執行看門狗機制
  3. 在scheduleExpirationRenewal中比較重要的方法就是renewExpiration,當線程第一次獲取到鎖(也就是不是重入的情況),那么就會調用renewExpiration方法開啟看門狗機制。
  4. 在renewExpiration會為當前鎖添加一個延遲任務task,這個延遲任務會在10s后執行,執行的任務就是將鎖的有效期刷新為30s(這是看門狗機制的默認鎖釋放時間)
  5. 并且在任務最后還會繼續遞歸調用renewExpiration。

首先獲取到鎖(這個鎖30s后自動釋放),然后對鎖設置一個延遲任務(10s后執行),延遲任務給鎖的釋放時間刷新為30s,并且還為鎖再設置一個相同的延遲任務(10s后執行),這樣就達到了如果一直不釋放鎖(程序沒有執行完)的話,看門狗機制會每10s將鎖的自動釋放時間刷新為30s。

startWatchdog方法啟動了一個定時任務,每隔10秒檢查一次當前持有的鎖,并調用checkAndExtendLocks方法延長鎖的過期時間。extendLeaseTime方法通過執行Redis腳本來更新鎖的過期時間,確保鎖在任務完成之前不會過期。

看門狗機制的優缺點

優點:
自動續期:看門狗機制可以自動續期鎖,確保任務在完成之前鎖不會過期。
可靠性高:通過定期檢查鎖的狀態,看門狗機制可以確保鎖的持有狀態,從而提高系統的可靠性。

缺點:
資源消耗:看門狗機制需要后臺線程定期檢查鎖的狀態,這會消耗一定的系統資源。
復雜性增加:看門狗機制的引入增加了系統的復雜性,可能需要額外的調試和維護工作。

優化

合理設置檢查頻率:根據任務的執行時間和系統的負載情況,合理設置看門狗線程的檢查頻率,既保證鎖的持有狀態,又減少系統資源的消耗。 優化Redis腳本:使用高效的Redis腳本來更新鎖的過期時間,減少Redis服務器的負載。 監控和報警:建立完善的監控和報警機制,及時發現和處理看門狗機制中的異常情況,確保系統的穩定性。

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

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

相關文章

[架構之美]linux常見故障問題解決方案(十九)

[架構之美]linux下常見故障問題解決方案 一,文本文件忙 問題一:rootwh-VMware-Virtual-Platform:/home/hail# cp /root/containerd/bin/* /usr/bin/ cp: 無法創建普通文件 ‘/usr/bin/containerd’: 文本文件忙 在Linux系統中遇到“文本文件忙”錯誤時…

QT實現曲線圖縮放、拖拽以及框選放大

.h文件 protected: void saveAxisRange();void wheelEvent(QWheelEvent *event) override;void mousePressEvent(QMouseEvent *event) override;void mouseMoveEvent(QMouseEvent *event) override;void mouseReleaseEvent(QMouseEvent *event) override;private:QPoint m_…

【Pandas】pandas DataFrame corr

Pandas2.2 DataFrame Computations descriptive stats 方法描述DataFrame.abs()用于返回 DataFrame 中每個元素的絕對值DataFrame.all([axis, bool_only, skipna])用于判斷 DataFrame 中是否所有元素在指定軸上都為 TrueDataFrame.any(*[, axis, bool_only, skipna])用于判斷…

青藏高原七大河流源區徑流深、蒸散發數據集(TPRED)

時間分辨率 月空間分辨率 1km - 10km共享方式 開放獲取數據大小 83.27 MB數據時間范圍 1998-07-01 — 2017-12-31元數據更新時間 2024-07-22 數據集摘要 通過構建耦合積雪、凍土、冰川等冰凍圈水文物理過程的WEB-DHM模型(Water and Energy Budget-based Distribute…

window環境下,如何通過USB接口控制打印機

雖然說大多數情況下,我們可以非常便利的通過打印機驅動來控制打印機,但還是有一些特殊情況,導致無法通過打印機驅動來完成我們預想的任務,比如,打印機只是一個系統設備中的一部分,需要協調其它設備一起工作…

CDGP數據治理主觀題評分標準與得分策略

1.數據模型題目評分標準 1)準確理解題目中所描述的業務邏輯和需求得[1分] 2)正確使用模型設計方法,使用信息工程、信息建模集成定義、巴克符號、陳氏符號等其中一種得[1分] 3)正確設計實體和屬性,題目中涉及的實體數量為25-30個,10個以內得[2分],10-20個得[3分],25個…

工業設計破局密碼:3D 可視化技術點燃產業升級引擎

3D可視化是一種將數據、信息或抽象概念以三維圖形、模型和動畫的形式呈現出來的技術。3D可視化技術通過構建三維數字孿生體,將設計思維轉化為可交互的虛擬原型,不僅打破了傳統二維設計的空間局限,更在效率、精度與用戶體驗層面開創了全新維度…

Qt中在子線程中刷新UI的方法

Qt中在子線程中刷新UI的方法 在Qt中UI界面并不是線程安全的,意味著在子線程中不能隨意操作UI界面組件(比如按鈕、標簽)等,如果強行操作這些組件有可能會導致程序崩潰。那么在Qt中如何在子線程中刷新UI控件呢? 兩種方…

為了摸魚和吃瓜,我開發了一個網站

平時上班真的比較累,摸魚和吃瓜還要跳轉多個平臺的話,就累上加累了。 所以做了一個聚合了全網主流平臺熱搜的網站。 目前市面上確實有很多這種網站了,所以目前最主要有兩點和他們不同: 給熱搜列表增加了配圖,刷的時候…

操作系統學習筆記第2章 (竟成)

第 2 章 進程管理 【考綱內容】 1.進程與線程: (1) 進程 / 線程的基本概念; (2) 進程 / 線程的狀態與轉換; (3) 線程的實現:內核支持的線程;線程庫支持的線程; (4) 進程與線程的組織與控制; (5)…

77.評論日記

房間要經常搞衛生,不然會很多灰,很多頭發,很多垃圾。 當然,即使一直搞衛生,在一些看不到的角落也是會慢慢囤積垃圾。 想要把那些角落也打掃干凈,沒別的辦法,只有把那個角落上所有的東西都移開&a…

語音合成之十二 TTS聲學編解碼器的演進

TTS聲學編解碼器的演進 1 引言:聲碼器/聲學編解碼器在現代TTS中的關鍵作用2 奠定基石:從早期聲碼器到神經合成的曙光3. HiFi-GAN: 革新高效高保真波形生成4. 新的疆域:面向富語義TTS的先進聲學編解碼器5. XCodec2.0: 統一聲學與語義信息6.BiC…

大學之大:悉尼科技大學2025.5.10

悉尼科技大學:從技術先驅到全球創新樞紐的百年征程 一、歷史沿革:從技工培訓到世界百強名校的蛻變 1. 工業革命的技術火種(1843-1945) 悉尼科技大學的歷史可追溯至1843年成立的悉尼機械學院(Sydney Mechanics’ Scho…

安裝阿里云的yum源并且下載軟件(CentOS7版本)

目錄 1. 進入root模式: 2. 進入yum.repos.d文件下 3.備份 4. 安裝阿里云的yum源 5. 安裝dnf 6. 安裝epel-release 7. 清除緩存,并新建緩存 8. 安裝智能拼音軟件包 8.1安裝 8.2 進入應用程序 -- 系統工具 -- 設置 8.3重啟后就可以打中文啦~ (需要重新啟動才能)…

Discriminative and domain invariant subspace alignment for visual tasks

用于視覺任務的判別性和域不變子空間對齊 作者:Samaneh Rezaei,Jafar Tahmoresnezhad 文章于2018年12月4日收到,2019年5月24日被接受,2019年6月3日在線發表于Iran Journal of Computer Science期刊,DOI: 10.1007/s42…

用jsp簡單實現C語言標準化測試系統

C語言標準化測試系統 在Web編程技術的學習過程中,我們小組為了深入理解相關技術原理,提升實踐能力,開發了一個基于動態Web工程框架的C語言標準化考試系統。現在,就來和大家分享一下我們的項目經歷。 一、實驗目的剖析 這個項目…

QMK鍵盤固件自定義指南 - 打造你的專屬鍵盤體驗

QMK鍵盤固件自定義指南 - 打造你的專屬鍵盤體驗 🚀 前言 在機械鍵盤的世界里,QMK固件讓你的鍵盤不再只是簡單的輸入設備,而是可以按照你的意愿定制的強大工具。本文將深入淺出地介紹如何自定義QMK鍵盤的行為,從基礎概念到高級應…

5.9培訓

文件上傳 先找文件上傳的地方,打開代理鏈接BP,它需要一個xls文件 我們創建一個sqzr.xls bp攔截了之后,我們修改請求,把后綴改成php,發送請求 找到我們的靜態資源所在的位置 訪問http://192.168.1.100:81/static/upload…

【FAQ】HarmonyOS SDK 閉源開放能力 — PDF Kit

1.問題描述: 預覽PDF文件,文檔上所描述的loadDocument接口,可以返回文件的狀態,并無法實現PDF的預覽,是否有能預覽PDF相關接口? 解決方案: 1、執行loadDocument進行加載PDF文件后&#xff0c…

AutoDL實現端口映射與遠程連接AutoDL與Pycharm上傳文件到遠程服務器(李沐老師的環境)

文章目錄 以上配置的作用前提AutoDL實現端口映射遠程連接AutoDLPycharm上傳文件到遠程服務器以上配置的作用 使用AutoDL的實例:因本地沒有足夠強的算力,所以需要使用AutoDL AutoDL端口映射:當在實例上安裝深度學習的環境,但因為實例的linux系統問題,無法圖形化顯示d2l中的文件…