一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

服務(wù)器之家:專注于服務(wù)器技術(shù)及軟件下載分享
分類導(dǎo)航

PHP教程|ASP.NET教程|Java教程|ASP教程|編程技術(shù)|正則表達式|C/C++|IOS|C#|Swift|Android|VB|R語言|JavaScript|易語言|vb.net|

服務(wù)器之家 - 編程語言 - PHP教程 - Laravel中為什么不使用blpop取隊列詳析

Laravel中為什么不使用blpop取隊列詳析

2019-09-17 13:40深 呼吸 PHP教程

這篇文章主要給大家介紹了關(guān)于Laravel中為什么不使用blpop取隊列的相關(guān)資料,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧

前言

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

blpop 不用一直輪詢,還可以同時取多個隊列,blpop high low 30,更方便實現(xiàn)隊列的優(yōu)先級。

安全隊列和不安全隊列

什么是不安全的隊列?比如客戶端 lpop(統(tǒng)一以 lpop 為例) 從 redis 取出來的 job(任務(wù))還沒處理完進程掛掉了或者遇到了異常,由于此時服務(wù)器上已經(jīng)沒有副本了,這個 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,如果隊列沒有數(shù)據(jù)過來,那么在超時時間內(nèi)就會一直阻塞,直到 rpush 數(shù)據(jù)到隊列,有點類似 http 的長輪詢,假如客戶端取出數(shù)據(jù)的這一刻掛了,還沒來得及暫存到另外的集合中,那么這個數(shù)據(jù)就丟失了。

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

Laravel中為什么不使用blpop取隊列詳析

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

Redis 官方文檔也有說明:

在MULTI/EXEC事務(wù)中的BLPOP

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

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

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

總結(jié)

以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,如果有疑問大家可以留言交流,謝謝大家對服務(wù)器之家的支持。

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 日本色吧| 娇妻与老头绿文小说系列 | 色播开心网| 国产精品成人 | 夫妇野外交换激情 | 国产性做久久久久久 | 午夜亚洲精品久久久久久 | 亚洲不卡视频 | 国产美女亚洲精品久久久久久 | 齐天大性之七仙女欲春迅雷链接 | 熟睡迷j系列小说 | 日本三级在线观看免费 | 日产2021免费一二三四区 | 亚洲欧美另类综合 | 国产一区在线免费观看 | 国内自拍2020 | 成人免费在线视频观看 | 五月婷婷在线观看 | 欧美色图日韩 | 俄罗斯毛片免费大全 | 亚洲男人天堂网址 | 久久热这里面只有精品 | 亚洲 日本 天堂 国产 在线 | 国产精品久久久久久影院 | 天天摸日日舔 | 青青青久热国产精品视频 | 26uuu成人人网图片 | 亚洲欧美天堂综合久久 | 久久er99热精品一区二区 | 欧美另类老女人 | 亚洲嫩模吧粉嫩粉嫩冒白浆 | 天美视频在线 | 男女男在线精品网站免费观看 | 国产免费一区二区三区免费视频 | 日本不卡1卡2卡三卡网站二百 | 俺不色| 亚洲精品tv久久久久久久久久 | 99在线观看国产 | 99在线视频观看 | 亚洲AV无码乱码在线观看浪潮 | 欧美国产在线 |