您现在的位置是:亿华云 > IT科技类资讯
Redisson 分布式锁源码之二:看门狗
亿华云2025-10-08 23:36:13【IT科技类资讯】4人已围观
简介前言说起 Redisson,比较耳熟能详的就是这个看门狗(Watchdog)机制。本文就一起看看加锁成功之后的看门狗(Watchdog)是如何实现的?1加锁成功在前一篇文章中介绍了可重入锁加锁的逻辑,
前言
说起 Redisson,分布比较耳熟能详的式锁就是这个看门狗(Watchdog)机制。
本文就一起看看加锁成功之后的源码看门狗(Watchdog)是如何实现的?
1加锁成功
在前一篇文章中介绍了可重入锁加锁的逻辑,其中 RedissonLock#tryAcquireAsync 方法是门狗进行异步加锁的逻辑。
回顾一下这个方法的分布入参:
waitTime:-1; leaseTime:-1,加锁时未指定锁时间,式锁则为 -1,源码如果指定,门狗则是分布指定的时间; unit:null; threadId:当前线程 id。其中的式锁 tryLockInnerAsync 在之前已经介绍过了。
当加锁成功时,源码会返回 null,门狗加锁失败,分布会返回当前锁的站群服务器式锁剩余时间。
所以这块会进入到红框标记的源码部分。
leaseTime 为加锁时间,默认不指定,所以会进入到 scheduleExpirationRenewal 方法,也就是今天的主题:看门狗。
至此可以得出一个结论:
Redisson 看门狗(Watchdog)在指定加锁时间时,是不会对锁时间自动续租的。
2看门狗
看门狗的一部分重点逻辑就在 renewExpiration 方法这里:
延迟调度,延迟时间为:internalLockLeaseTime / 3,就是 10s 左右后会调度这个 TimerTask; 异步续租:逻辑都在 renewExpirationAsync 里面; 递归调用:当续租成功之后,重新调用 renewExpiration 自己,从而达到持续续租的目的; 当然也不能一直无限续租,所以中间有一些判断逻辑,就是用来中断续租的免费信息发布网。续租逻辑
这块也是一个 lua 脚本,就是将之前的 redis key 直接重新设置时间。
这样一通续租下来,就是在过了 10s 左右将锁的时间重新设置为 30s。
3总结
至此,看门狗介绍完毕,简要总结一下内容。
只有在未指定锁超时时间时才会使用看门狗;
看门狗默认续租时间是 10s 左右,internalLockLeaseTime / 3;
可以通过 Config 统一设置看门狗的时间,设置 lockWatchdogTimeout 参数即可。
最后,同样使用一张图,进行下总结:
本文转载自微信公众号「程序员小航」,可以通过以下二维码关注。转载本文请联系程序员小航公众号。
很赞哦!(31)
相关文章
- 比较短的域名方便用户记忆和传播,它带来的好处往往会超过其他类型的域名,如果你非要域名短而且还要包含关键词,那么往往会事与愿违,现在这种域名基本上是可遇而不可求的。
- 13年资深开发者分享一年学习Rust经历:从必备书目到代码练习一网打尽
- Spring Cloud:使用Ribbon实现负载均衡详解(上)
- 小程序不让用 JS 解释器?那我再杠一次鹅厂
- 公司名字不但要与其经营理念、活动识别相统一,还要能反映公司理念,服务宗旨、商品形象,从而才能使人看到或听到公司的名称就能产生愉快的联想,对商店产生好感。这样有助于公司树立良好的形象。
- 域名的特性有哪些?新手如何依据找域名?
- 不同业务场景该如何选择缓存的读写策略?
- Spring Security(三)--核心配置解读
- 在众多公司中,如果我们必须选择一家可信的公司,那当然是信得过的。
- Spring Boot快速接入Prometheus监控