面试官:Redis分布式锁如何续期?

本文通过一个面试问题探讨Redis分布式锁的正确使用方式,强调使用redisson客户端,并分析了Redis分布式锁的超时时间、看门狗机制以及源码中的锁续期逻辑。默认情况下,锁超时时间为30秒,看门狗会在锁即将到期时进行续期,如果业务机器宕机,锁将在30秒后自动释放。
摘要由CSDN通过智能技术生成

 

一、真实案例

二、Redis分布式锁的正确姿势

很多同学在用分布式锁时,都是直接百度搜索找一个Redis分布式锁工具类就直接用了.关键是该工具类中还充斥着很多System.out.println();等语句.其实Redis分布式锁比较正确的姿势是采用redisson这个客户端工具.具体介绍可以搜索最大的同性交友网站github.

三、如何回答

首先如果你之前用Redis的分布式锁的姿势正确,并且看过相应的官方文档的话,这个问题So easy.我们来看

坦白说,如果你英文棒棒哒那么看英文文档可能更好理解 By default lock watchdog timeout is 30 seconds and can be changed through Config.lockWatchdogTimeout setting. 但是你如果看的是中文文档 看门狗检查锁的超时时间默认是30秒 这句话从语文角度分析就是一个歧义句,他有两个意思

1.看门狗默认30秒去检查一次锁的超时时间

2.看们狗会去检查锁的超时时间,锁的时间时间默认是30秒

看到这里,我希望大家不要黑我的小学体育老师,虽然他和语文老师是同个人.语文不行,我们可以源码来凑!

四、源码分析

我们根据官方文档给出的例子,写了一个最简单的demo,例子根据上面截图中Ctr+C和Ctr+V一波操作

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值