国产xxxx99真实实拍_久久不雅视频_高清韩国a级特黄毛片_嗯老师别我我受不了了小说

資訊專欄INFORMATION COLUMN

php redis 加鎖與解鎖

JellyBool / 3463人閱讀

摘要:將用戶添加進房間李四王五李四王五張三腳本解鎖先判斷的值是否為才會刪除所以的設計要有隨機唯一性具體還可以看看這篇文章解鎖鎖的正確姿勢還有操作的文檔里面有函數的解釋注意用腳本這里需要開放等系統函數以上代碼僅作參考

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 / FALSE
while(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 0
end ";
$this->redis->eval($script, array($key , $value), 1);

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

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

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

文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。

轉載請注明本文地址:http://specialneedsforspecialkids.com/yun/28856.html

相關文章

  • 基于Redis實現分布式鎖

    摘要:本篇博客將介紹第二種方式,基于的實現分布式鎖。總結本文主要介紹了如何使用代碼正確實現分布式鎖,對于加鎖和解鎖也分別給出了兩個比較經典的錯誤示例。其實想要通過實現分布式鎖并不難,只要保證能滿足可靠性里的四個條件。 前言 分布式鎖一般有三種實現方式:1.數據庫樂觀鎖;2、基于Redis的分布式鎖;3.基于Zookeeper的分布式鎖。本篇博客將介紹第二種方式,基于Redis的實現分布式鎖。...

    jonh_felix 評論0 收藏0
  • 【Java貓說】Java多線程之內存可見性(上篇)

    摘要:貓說多線程之內存可見性下篇歡迎你留言討論屬于你的見解,畢竟每個人的味蕾都不一樣,這杯咖啡有吸引到你嗎好像又是一個槽糕的比喻本文已轉載個人技術公眾號歡迎留言討論與點贊上一篇推薦貓說主數據類型和引用下一篇推薦貓說多線程之內存可見性下篇 閱讀本文約3分鐘 本文大致講述兩種線程實現的可見性,或許你已經提前想到了,那說明你的基礎很好,我們要聊聊synchronized實現可見性與volatil...

    khlbat 評論0 收藏0

發表評論

0條評論

最新活動
閱讀需要支付1元查看
<