【学习日记七------分布式锁问题】

问题: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
在这里插入图片描述

参考资料:
Redis 分布式锁过期了,但业务还没有执行完,怎么办
Redisson解决redis分布式锁过期时间到了业务没执行完问题
redis分布式锁常见问题
Redisson 分布式锁的watch dog自动续期机制

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值