redisson 分布式锁的看门狗机制,如果业务处理一直没处理完,那看门狗的锁机制会一直不释放锁,这样不是造成死锁了吗 是怎么处理的
12条回答 默认 最新
无所不用齐极 2022-11-25 02:57关注我大概理解你的意思,我也思考过这个问题,因为我把宕机和线程阻塞混为一谈了,线程阻塞是在没有宕机的情况下发生的。
看门狗的作用,考虑以下三种情况:
1,如果没有设置锁的过期时间,单靠逻辑来释放锁,就会出现获取锁的节点宕机时,锁没有释放,造成死锁。
2,如果设置了某个过期时间,在没有宕机的情况下,线程发生了阻塞,就会导致锁过期自动释放,带来一些其他的问题。
3,如果设置了看门狗,在没有宕机时,如果发生了阻塞,那么看门狗就能一直给线程续时间;如果宕机了,看门狗不起作用,过了有效期之后就会自动释放掉锁,不会造成死锁。
总结来说就是,在正常运行时,能够给锁加无限有效期,宕机时,能释放。评论 打赏 举报解决 21无用