一、场景分析
前几天在做分布式锁测试:
在调试模式下,lock.lock() 之后打上断点,想测试一下在当前线程放弃锁之前,别的线程能否获取得到锁。
发现调试模式下,看门狗机制失效了,Redis 上 30 秒后,锁就没了:
看门狗失效
尝试改为 Thread.sleep 之后就可以了:
看门狗正常
会先有一个 30 秒的锁,倒计时到 20 秒的时候,又续期为 30 秒,就这样跑了 40 秒以后,锁释放。
二、原因分析
具体原因没有深究,AI 给出的解释是:
可以得真正去探究 JVM 跟调试机之间的通信协议,才能真正了解。