作者:程序员小航 2021-06-28 10:51:55
前端
分布式
Redis 说起 Redisson,比较耳熟能详的就是这个看门狗(watchdog)机制。本文就一起看看加锁成功之后的看门狗(Watchdog)是如何实现的?
创新互联专注于美兰网站建设服务及定制,我们拥有丰富的企业做网站经验。 热诚为您提供美兰营销型网站建设,美兰网站制作、美兰网页设计、美兰网站官网定制、微信小程序服务,打造美兰网络公司原创品牌,更为您提供美兰网站排名全网营销落地服务。
说起 Redisson,比较耳熟能详的就是这个看门狗(Watchdog)机制。
本文就一起看看加锁成功之后的看门狗(Watchdog)是如何实现的?
在前一篇文章中介绍了可重入锁加锁的逻辑,其中 RedissonLock#tryAcquireAsync 方法是进行异步加锁的逻辑。
回顾一下这个方法的入参:
其中的 tryLockInnerAsync 在之前已经介绍过了。
当加锁成功时,会返回 null,加锁失败,会返回当前锁的剩余时间。
所以这块会进入到红框标记的部分。
leaseTime 为加锁时间,默认不指定,所以会进入到 scheduleExpirationRenewal 方法,也就是今天的主题:看门狗。
至此可以得出一个结论:
Redisson 看门狗(Watchdog)在指定加锁时间时,是不会对锁时间自动续租的。
看门狗的一部分重点逻辑就在 renewExpiration 方法这里:
续租逻辑
这块也是一个 lua 脚本,就是将之前的 redis key 直接重新设置时间。
这样一通续租下来,就是在过了 10s 左右将锁的时间重新设置为 30s。
至此,看门狗介绍完毕,简要总结一下内容。
只有在未指定锁超时时间时才会使用看门狗;
看门狗默认续租时间是 10s 左右,internalLockLeaseTime / 3;
可以通过 Config 统一设置看门狗的时间,设置 lockWatchdogTimeout 参数即可。
最后,同样使用一张图,进行下总结:
本文转载自微信公众号「程序员小航」,可以通过以下二维码关注。转载本文请联系程序员小航公众号。
当前题目:Redisson分布式锁源码之二:看门狗
文章分享:http://www.csdahua.cn/qtweb/news0/89850.html
网站建设、网络推广公司-快上网,是专注品牌与效果的网站制作,网络营销seo公司;服务项目有等
声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 快上网