Redisson 分布式锁源码 02:看门狗
2021/7/3 19:22:34
本文主要是介绍Redisson 分布式锁源码 02:看门狗,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!
前言
说起 Redisson,比较耳熟能详的就是这个看门狗(Watchdog)机制。
本文就一起看看加锁成功之后的看门狗(Watchdog)是如何实现的?
加锁成功
在前一篇文章中介绍了可重入锁加锁的逻辑,其中 RedissonLock#tryAcquireAsync
方法是进行异步加锁的逻辑。
回顾一下这个方法的入参:
- waitTime:-1;
- leaseTime:-1,加锁时未指定锁时间,则为 -1,如果指定,则是指定的时间;
- unit:null;
- threadId:当前线程 id。
其中的 tryLockInnerAsync
在之前已经介绍过了。
当加锁成功时,会返回 null,加锁失败,会返回当前锁的剩余时间。
所以这块会进入到红框标记的部分。
leaseTime 为加锁时间,默认不指定,所以会进入到 scheduleExpirationRenewal
方法,也就是今天的主题:看门狗。
至此可以得出一个结论:
Redisson 看门狗(Watchdog)在指定加锁时间时,是不会对锁时间自动续租的。
看门狗
看门狗的一部分重点逻辑就在 renewExpiration
方法这里:
- 延迟调度,延迟时间为:
internalLockLeaseTime / 3
,就是 10s 左右后会调度这个 TimerTask; - 异步续租:逻辑都在 renewExpirationAsync 里面;
- 递归调用:当续租成功之后,重新调用
renewExpiration
自己,从而达到持续续租的目的; - 当然也不能一直无限续租,所以中间有一些判断逻辑,就是用来中断续租的。
续租逻辑
这块也是一个 lua 脚本,就是将之前的 redis key 直接重新设置时间。
这样一通续租下来,就是在过了 10s 左右将锁的时间重新设置为 30s。
总结
至此,看门狗介绍完毕,简要总结一下内容。
- 只有在未指定锁超时时间时才会使用看门狗;
- 看门狗默认续租时间是 10s 左右,
internalLockLeaseTime / 3
; - 可以通过 Config 统一设置看门狗的时间,设置
lockWatchdogTimeout
参数即可。
最后,同样使用一张图,进行下总结:
相关推荐
- Redisson 分布式锁源码 01:可重入锁加锁
- Spring 是如何解决循环依赖的?
- Spring 自调用事务失效,你是怎么解决的?
这篇关于Redisson 分布式锁源码 02:看门狗的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!
- 2024-05-31Tiny RDM:你的下一代Redis桌面GUI神器-icode9专业技术文章分享
- 2024-03-21redisinsight-v2
- 2024-02-26Typed property App\Api\Mapper\GamePropsConfigMapper::$apiRedis must not be accessed before initia-icode9专业技术文章分享
- 2024-02-21redisson getlock
- 2024-02-20redis config
- 2024-02-20redis leaderboard
- 2024-01-23缓存选型:Redis or MemCache
- 2024-01-22面试官:Redis持久化能关吗?怎么关?
- 2024-01-21Redis压测工具redis-benchmark-icode9专业技术文章分享
- 2024-01-19这才是你应该了解的Redis数据结构!