资深面试官:你们项目中的分布式锁是怎么实现的?
老任:基于redis的set命令,该命令有nx和ex选项。
资深面试官:那如果锁到期了,业务还没结束,如何进行自动续期呢?
老任:这个…面试官,您上个问题是啥来着?
资深面试官:你们项目中分布式锁是怎么实现的。
老任:我们直接使用了Redisson中提供的分布式锁。
资深面试官:你给我滚!!!
Redisson的看门狗机制
使用redis分布式锁时,为了防止种种异常情况下,锁无法正常“释放”的情况,我们都会为锁设置个超时时间。
这时候,又会存在一个尴尬的情况,如果设置了超时时间,但在规定的时间内,业务逻辑还没有执行完,锁就被释放了…那么针对一些特定的业务逻辑,这可能又会引起新的问题…
所以Redisson就给我们提供了监控锁的看门狗机制,通过该机制,锁被关闭前,看门狗会不断的延长锁的超时时间。默认情况下,看门狗的锁超时时间lockWatchdogTimeout是30s,该值当然也是可以设置的。
源码伺候
现在让我们进入tryLock()方法来查看一下实现源码,在该方法中调用tryAcquire()方法。
tryAcquire()方法中调用tryAcquireAsync()方法。
tryAcquireAsync()方法中,如果leaseTime小于等于0,调用scheduleExpirationRenewal方法进行续期。
给大家的福利
零基础入门
对于从来没有接触过网络安全的同学,我们帮你准备了详细的学习成长路线图。可以说是最科学最系统的学习路线,大家跟着这个大的方向学习准没问题。
同时每个成长路线对应的板块都有配套的视频提供:
因篇幅有限,仅展示部分资料
网络安全面试题
绿盟护网行动
还有大家最喜欢的黑客技术
网络安全源码合集+工具包
所有资料共282G,朋友们如果有需要全套《网络安全入门+黑客进阶学习资源包》,可以扫描下方二维码领取(如遇扫码问题,可以在评论区留言领取哦)~