亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Laravel中不使用blpop取隊列的原因是什么

發布時間:2021-02-05 14:38:36 來源:億速云 閱讀:159 作者:小新 欄目:開發技術

小編給大家分享一下Laravel中不使用blpop取隊列的原因是什么,希望大家閱讀完這篇文章之后都有所收獲,下面讓我們一起去探討吧!

前言

Redis 的 list 數據結構常用來做消息隊列,通常使用的命令有 lpop/rpop ,還有帶阻塞版的 blpop/brpop 等。Laravel 5.3 消息隊列也是用的 lpop 取消息,為什么不用阻塞版的 blpop 呢?

blpop 不用一直輪詢,還可以同時取多個隊列,blpop high low 30,更方便實現隊列的優先級。

安全隊列和不安全隊列

什么是不安全的隊列?比如客戶端 lpop(統一以 lpop 為例) 從 redis 取出來的 job(任務)還沒處理完進程掛掉了或者遇到了異常,由于此時服務器上已經沒有副本了,這個 job 就丟失了。這種隊列就是不安全的。

Laravel 正是為了保證消息隊列的可靠,進程掛掉了或者處理失敗還可以重試等,做了比較完善的機制,如取隊列的同時把隊列放入另一個集合中“暫存”起來。如代碼所示,使用 lpop 取出隊列,同時 zadd 到另一個集合,使用 redis lua 來保證原子性。

public static function pop()
{
 return <<<'LUA'
-- Pop the first job off of the queue...
local job = redis.call('lpop', KEYS[1])
local reserved = false
 
if(job ~= false) then
-- Increment the attempt count and place job on the reserved queue...
reserved = cjson.decode(job)
reserved['attempts'] = reserved['attempts'] + 1
reserved = cjson.encode(reserved)
redis.call('zadd', KEYS[2], ARGV[1], reserved)
end
 
return {job, reserved}
LUA;
}

為什么不用 blpop?

這里為什么不使用阻塞版本的 blpop 呢?

blpop 是阻塞版的 lpop,如果隊列沒有數據過來,那么在超時時間內就會一直阻塞,直到 rpush 數據到隊列,有點類似 http 的長輪詢,假如客戶端取出數據的這一刻掛了,還沒來得及暫存到另外的集合中,那么這個數據就丟失了。

你可能會問為何不跟 lpop 一樣用 lua 腳本來處理并保證原子性?這個問題作者在 github 上有回答。(https://github.com/laravel/framework/issues/22939)

Laravel中不使用blpop取隊列的原因是什么

我們知道 redis lua 腳本實際上就是事務,作者的大意也是說 MULTI/EXEC 包裹起來的 blpop 沒有意義,這個時候它“退化”為非阻塞版的。

Redis 官方文檔也有說明:

在MULTI/EXEC事務中的BLPOP

BLPOP 可以用于流水線(pipline,批量地發送多個命令并讀入多個回復),但把它用在 MULTI / EXEC 塊當中沒有意義。因為這要求整個服務器被阻塞以保證塊執行時的原子性,該行為阻止了其他客戶端執行 LPUSH 或 RPUSH 命令。

因此,一個被包裹在 MULTI / EXEC 塊內的 BLPOP 命令,行為表現得就像 LPOP 一樣,對空列表返回 nil ,對非空列表彈出列表元素,不進行任何阻塞操作。

因此通過 lua 腳本操作 blpop 和 zadd 也沒有意義,結論就是:因為沒用到阻塞的特性,或者無法保證原子性。

看完了這篇文章,相信你對“Laravel中不使用blpop取隊列的原因是什么”有了一定的了解,如果想了解更多相關知識,歡迎關注億速云行業資訊頻道,感謝各位的閱讀!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

茌平县| 亳州市| 呈贡县| 裕民县| 新乐市| 民乐县| 若尔盖县| 拉萨市| 正安县| 西华县| 宝清县| 青阳县| 丹巴县| 赤城县| 罗甸县| 萨迦县| 盐源县| 马边| 长宁区| 崇礼县| 枣庄市| 耒阳市| 梓潼县| 莫力| 澜沧| 宝应县| 马公市| 通化市| 邵武市| 土默特右旗| 邹平县| 镇平县| 镇远县| 嘉鱼县| 舒城县| 阜新| 沧州市| 炎陵县| 积石山| 崇礼县| 攀枝花市|