深入Redis分布式锁

基础知识

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

        SETNX key value

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

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

问题解答

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

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

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

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

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

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

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

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

 

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章