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 就可以获取到值 而…