php redis的加鎖與解鎖

來源:互聯網
上載者:User
這篇文章主要介紹了關於php redis的加鎖與解鎖,有著一定的參考價值,現在分享給大家,有需要的朋友可以參考一下

php+redis 實現加鎖與解鎖操作

業務背景:在房間棋牌遊戲中需要用到鎖來防止並行作業引起的 redis 資料髒讀問題;例如添加使用者進入房間的動作:

並發的情況下,get RoomUsers 會有髒讀現象;

解決思路:加鎖房間來實現 一個房間每次只允許一個用戶端操作,其他並發用戶端則等待;也就是-----堵塞鎖;

加鎖:redis加鎖方式有幾種: incr、set、setnx、hSetnx,可以參考這篇文章:redis加鎖的幾種實現

這裡我用到 set 這種方式

$roomId = $_GET['roomId'];$user = $_GET['user'];             // '張三'$key = "LockRoom:{$roomId}";$value = $roomId.uniqid();$ex = 3;// 如果 $key 不存在的話,就設定 $key 的值為 $value,且有效期間為 3s; // return TRUE / FALSEwhile(true){    $res  = $this->redis->set($key, $value, ['nx', 'ex' => $ex]);    if($res) { break; }    usleep(5000);}// 將使用者添加進房間$roomUsers = $this->redis->get("Room:{$roomId}:Users"); // ['李四', '王五']$roomUsers[] = $user;$this->redis->set("Room:{$roomId}:Users", $roomUsers); // ['李四', '王五', '張三']

解鎖:操作完當然要解鎖了,不解鎖起碼要等待 3秒;
解鎖用 delete 刪除 key; 但是這裡有個坑,不能直接用 delete,因為假設 client01 獲得了鎖,在添加使用者進入房間的過程中 時間超過了 3秒 ,這個時候client02 就會同樣獲得鎖並且設定3S,然後當client01 操作完之後 delete key , 就把 client02 設定的鎖刪除了;
這裡推薦用 lua 代碼執行刪除,因為lua 執行具有原子性。

// 將使用者添加進房間$roomUsers = $this->redis->get("Room:{$roomId}:Users"); // ['李四', '王五']$roomUsers[] = $user;$this->redis->set("Room:{$roomId}:Users", $roomUsers); // ['李四', '王五', '張三']// lua 指令碼解鎖// 先判斷 key的值是否為 value, TRUE 才會刪除, 所以 $value 的設計要有隨機唯一性$script = 'if redis.call("get",KEYS[1]) == ARGV[1]then    return redis.call("del",KEYS[1])else    return 0end ';$this->redis->eval($script, array($key , $value), 1);

具體還可以看看 這篇文章:解鎖 Redis 鎖的正確姿勢

還有php操作redis的文檔:PhpRedis 裡面有 set()、eval() 函數的解釋

注意:用 lua 指令碼這裡 php.ini 需要開放 shell_exec() 等系統函數
以上代碼僅作參考!!

以上就是本文的全部內容,希望對大家的學習有所協助,更多相關內容請關注topic.alibabacloud.com!

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.