REDIS中加鎖和解鎖問題


使用lua+redis的方法。之所以使用lua是為了保證原子性

問題:

1、 redis發現鎖失敗了要怎么辦?中斷請求還是循環請求?
2、 循環請求的話,如果有一個獲取了鎖,其它的在去獲取鎖的時候,是不是容易發生搶鎖的可能?
3、 鎖提前過期后,客戶端A還沒執行完,然后客戶端B獲取到了鎖,這時候客戶端A執行完了,會不會在刪鎖的時候把B的鎖給刪掉?

針對問題1:使用循環請求,循環請求去獲取鎖
針對問題2:針對第二個問題,在循環請求獲取鎖的時候,加入睡眠功能,等待幾毫秒在執行循環
針對問題3:在加鎖的時候存入的key是隨機的。這樣的話,每次在刪除key的時候判斷下存入的key里的value和自己存的是否一樣

        do {  //針對問題1,使用循環
            $timeout = 10;
            $roomid = 10001;
            $key = 'room_lock';
            $value = 'room_'.$roomid;  //分配一個隨機的值針對問題3
            $isLock = Redis::set($key, $value, 'ex', $timeout, 'nx');//ex 秒
            if ($isLock) {
                if (Redis::get($key) == $value) {  //防止提前過期,誤刪其它請求創建的鎖
                    //執行內部代碼
                    Redis::del($key);
                    continue;//執行成功刪除key並跳出循環
                }
            } else {
                usleep(5000); //睡眠,降低搶鎖頻率,緩解redis壓力,針對問題2
            }
        } while(!$isLock);

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM