提及 Redisson,比较耳熟能详的就是这个看门狗(Watchdog)机制。redis
本文就一块儿看看加锁成功以后的看门狗(Watchdog)是如何实现的?异步
在前一篇文章中介绍了可重入锁加锁的逻辑,其中 RedissonLock#tryAcquireAsync
方法是进行异步加锁的逻辑。分布式
回顾一下这个方法的入参:ui
其中的 tryLockInnerAsync
在以前已经介绍过了。lua
当加锁成功时,会返回 null,加锁失败,会返回当前锁的剩余时间。spa
因此这块会进入到红框标记的部分。线程
leaseTime 为加锁时间,默认不指定,因此会进入到 scheduleExpirationRenewal
方法,也就是今天的主题:看门狗。code
至此能够得出一个结论:递归
Redisson 看门狗(Watchdog)在指定加锁时间时,是不会对锁时间自动续租的。事务
看门狗的一部分重点逻辑就在 renewExpiration
方法这里:
internalLockLeaseTime / 3
,就是 10s 左右后会调度这个 TimerTask;renewExpiration
本身,从而达到持续续租的目的;这块也是一个 lua 脚本,就是将以前的 redis key 直接从新设置时间。
这样一通续租下来,就是在过了 10s 左右将锁的时间从新设置为 30s。
至此,看门狗介绍完毕,简要总结一下内容。
internalLockLeaseTime / 3
;lockWatchdogTimeout
参数便可。最后,一样使用一张图,进行下总结: