深入Redis分布式锁

基础知识

Redis提供了函数来支持分布式锁:

        SETNX key value

当且仅当 key 不存在时才能设置成功。设置成功时,返回1;反之,返回0。

如果锁设置失败,说明已经有其他任务获取了这把锁,可以通过循环的方式不断地尝试获取锁。

问题解答

(1)如果获得锁的任务因为不可抗力挂掉了,比如断电停机,怎么保证锁能被释放?

         通过设置超时时间来解决这个问题。

(2)假设超时时间到了,但是获得锁的任务还没执行完,应该怎么办?

       编写守护线程,不断的检测是否存在超时时间已经结束,但是任务还没执行完的情况。如果条件满足,那么重置超时时间。

(3)如何避免大量锁同时过期的情况(会导致Redis短时间内阻塞)?

       将超时时间*随机数代替固定的 值。

(4)会存在两个任务同时获得了锁的情况吗?怎么处理?

      会。假设任务一的超时时间刚到,任务二马上获得 了锁,这时候就会导致两个任务都获得了锁。解决方案当然是避免这种情况的发生,可以采用(2)的 方案+调大任务二尝试获取锁的时间间隔。但是治标不治本,这个问题终究是无法完全避免的。

 

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值