Redisson 分布式锁源码之二:看门狗
2023-03-14 09:40:25 时间
前言
说起 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 参数即可。
最后,同样使用一张图,进行下总结:
本文转载自微信公众号「程序员小航」,可以通过以下二维码关注。转载本文请联系程序员小航公众号。
相关文章
- 对话院士张钹:人工智能创业如何避免昙花一现
- 深入理解Spark:核心思想与源码分析. 2.3 Spark基本设计思想
- 深入理解Spark:核心思想与源码分析. 2.5 小结
- LinkedIn前数据专家解读日志与实时流处理
- 深入理解Spark:核心思想与源码分析. 3.9 启动测量系统MetricsSystem
- 互联网热潮渐远,数据领域风投们将关注什么?
- Hadoop创始人Doug Cutting谈未来大数据的技术
- 【综述】情感计算的“前世今生”
- 16位天才的思维创造让数据科学更简单
- 欧洲核子研究组织如何预测新的流行数据集?
- Java RESTful Web Service实战(第2版) 2.3 传输格式
- Java RESTful Web Service实战(第2版) 2.6 内容协商
- 德国队的大数据策略|虽然被淘汰了但是人家准备很充分啊
- 母亲节 | 大数据解读妈妈们的时间都去哪了
- 企业IT架构转型之道:阿里巴巴中台战略思想与架构实战. 3.1 淘宝平台“服务化”历程
- Ceph分布式存储实战3.2 CRUSH基本原理
- Ceph分布式存储实战3.3 CRUSH关系分析
- 聚焦开放数据:全球恐怖袭击事件数据库
- 数据分析师的职业规划之路
- 数据实践之美:31位大数据专家的方法、技术与思想. 导读