Java 调试模式下 Redisson 看门狗失效

一、场景分析

前几天在做分布式锁测试:

在调试模式下,lock.lock() 之后打上断点,想测试一下在当前线程放弃锁之前,别的线程能否获取得到锁。

 发现调试模式下,看门狗机制失效了,Redis 上 30 秒后,锁就没了:

看门狗失效

尝试改为 Thread.sleep 之后就可以了:

看门狗正常

会先有一个 30 秒的锁,倒计时到 20 秒的时候,又续期为 30 秒,就这样跑了 40 秒以后,锁释放。

 二、原因分析

具体原因没有深究,AI 给出的解释是:

 可以得真正去探究 JVM 跟调试机之间的通信协议,才能真正了解。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值