问题:Redis 分布式锁过期了,但业务还没有执行完,怎么办?
第一种方法(自己实现):
1、问:redis分布式锁过期了,但是业务还没有执行完,怎么办?
答:可以对锁进行续期操作。
2、问:怎么续期?
答:在项目中启用一个WatchDog(看门狗),每隔一段时间(比如10s)为当前分布式锁进行续期操作,续期时就是每隔10s进行重新设置当前key过期时间。
3、WatchDog怎么实现的?
答:在项目中启动一个定时任务,每隔10s来检查分布式锁的key是否还存在,如果存在,说明业务还未处理完,进行续期操作。
4、如果你续期的这个key是其它请求写入的呢?怎么办?
答:未每次请求设置一个唯一标识id,在设置的value中增加这样一个唯一标识的前缀,锁续期的时候,根据当前分布式锁的value的前缀来判断是不是同一个请求,如果是则续期,如果不是则放任不管。
第二种方法(redisson):
1、warchdog机制:
如果拿到分布式锁的节点宕机,且这个锁正好处于锁住的状态时,会出现锁死的状态,为了避免这种情况的发生,锁都会设置一个过期时间。这样也存在一个问题,加入一个线程拿到了锁设置了30s超时,在30s后这个线程还没有执行完毕,锁超时释放了,就会导致问题,Redisson给出了自己的答案,就是 watch dog 自动延期机制。
Redisson提供了一个监控锁的看门狗,它的作用是在Redisson实例被关闭前,不断的延长锁的有效期,也就是说,如果一个拿到锁的线程一直没有完成逻辑,那么看门狗会帮助线程不断的延长锁超时时间,锁不会因为超时而被释放。
默认情况下,看门狗的续期时间是30s,也可以通过修改Config.lockWatchdogTimeout来另行指定。
另外Redisson 还提供了可以指定leaseTime参数的加锁方法来指定加锁的时间。超过这个时间后锁便自动解开了,不会延长锁的有效期。
2、api:
try{
Lock lock = redisson.getLock("lock_key");
lock.lock();
}catch(Exception e){
log.error(****);
}finally{
lock.unLock();
}
redisson分布式锁看门狗自动续期流程:
参考资料:
Redis 分布式锁过期了,但业务还没有执行完,怎么办
Redisson解决redis分布式锁过期时间到了业务没执行完问题
redis分布式锁常见问题
Redisson 分布式锁的watch dog自动续期机制