实战都通用的 Watchdog 原理说明

一句话先给你结论

Redis Watchdog 是 Redisson 分布式锁的"自动续命机制",用于防止业务还没执行完,锁却过期被别人抢走。

它不是 Redis 内置功能,是 Redisson 客户端实现的


一、没有 Watchdog 会发生什么?

你用 Redis 锁时,通常这样:

SET order_lock user1 NX EX 30

含义:

user1 拿锁 30 秒

如果你的业务跑了 45 秒:

时间 发生什么
0s user1 拿锁
30s Redis 自动释放锁
31s user2 拿到锁
45s user1 还在执行业务

结果:

两个人同时改订单 ------ 数据直接炸了


二、Watchdog 是怎么解决这个问题的?

Redisson 不给锁设置固定过期时间,而是:

给锁一个"默认租期" + 后台线程自动续期

默认:

锁有效期 = 30 秒 每 10 秒自动续 30 秒


三、Watchdog 的工作机制

当你调用:

RLock lock = redisson.getLock("order_lock");

lock.lock(); // 没有指定过期时间

Redisson 在内部做了三件事:

1️⃣ 获取锁

SET order_lock uuid NX PX 30000

成功后,启动一个后台线程(Watchdog)


2️⃣ Watchdog 定时续期

每隔 10 秒执行 Lua 脚本:

if redis.call("get", "order_lock") == uuid then redis.call("pexpire", "order_lock", 30000) end

含义:

只要还是我持有锁,就帮我续命 30 秒


3️⃣ 业务完成,释放锁

lock.unlock();

Redisson:

  • 删除 Redis key

  • 停止 Watchdog 线程


四、为什么 Watchdog 不会"误续别人锁"?

因为:

锁里存的是 UUID

只有:

value == 当前客户端 uuid

才会续期。

别人抢到锁后:

  • value 已变

  • Watchdog 续期失败


五、Watchdog 解决的本质问题

它解决的是:

"分布式锁的持有时间 ≠ 业务执行时间"

它让锁变成:

跟着业务跑,而不是跟着 TTL 跑


六、你在面试中可以这样说

Redis 的 Watchdog 是 Redisson 实现的一种自动续期机制,通过后台定时任务 + Lua 脚本,只要客户端还持有锁,就不断延长锁的 TTL,防止长事务执行时锁提前过期导致并发安全问题。

这是架构师级标准答案


七、一个高级追问你也能接住

问:Watchdog 会不会导致死锁?

答:

不会。

如果进程挂了,Watchdog 线程也会消失,锁不会再续期,TTL 到期后自动释放。

相关推荐
ALex_zry21 小时前
Redis Cluster 分布式缓存架构设计与实践
redis·分布式·缓存
马猴烧酒.1 天前
【面试八股|Java集合】Java集合常考面试题详解
java·开发语言·python·面试·八股
乔江seven1 天前
【Flask 进阶】3 从同步到异步:基于 Redis 任务队列解决 API 高并发与长耗时任务阻塞
redis·python·flask
这周也會开心1 天前
Redis与MySQL回写中的数据类型存储设计
数据库·redis·mysql
shuair1 天前
redis缓存预热、缓存击穿、缓存穿透、缓存雪崩
redis·spring·缓存
闻哥1 天前
从测试坏味道到优雅实践:打造高质量单元测试
java·面试·单元测试·log4j·springboot
shuair1 天前
guava布隆过滤器及cuckoo过滤器
redis·guava
上架ipa1 天前
redis图形化客户端功能对比
redis·缓存
南风知我意9571 天前
【前端面试5】手写Function原型方法
前端·面试·职场和发展
java1234_小锋1 天前
Java高频面试题:SpringBoot如何自定义Starter?
java·spring boot·面试