婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > 關于 Laravel Redis 多個進程同時取隊列問題詳解

關于 Laravel Redis 多個進程同時取隊列問題詳解

熱門標簽:商丘外呼系統好處 隨州銷售電銷機器人公司 福建高頻外呼防封系統哪家好 周口網絡回撥外呼系統 外呼系統人工客服 網絡電話400申請 400電話申請辦理 全國各省地圖標注點 百度地圖標注類型是酒店

前言

最近在工作中遇到了一個問題,開啟多個進程處理隊列會重復讀取 Redis 中隊列嗎?是否因此導致重復執行任務?下面就來通過示例代碼詳細介紹下。

使用 Supervisor 監聽 Laravel 隊列任務,其中 Supervisor 的配置如下:

[program:laravel-worker]
process_name=%(program_name)s_%(process_num)02d
command=php /var/www/xxx.cn/artisan queue:work --queue=sendfile --tries=3 --daemon
autostart=true
autorestart=true
numprocs=8
redirect_stderr=true
stdout_logfile=/var/www/xxx.cn/worker.log

注意: numprocs = 8,代表開啟 8 個進程來執行 command 中的命令。

如下:

PS C:\Users\tanteng\website\laradock> docker-compose exec php-worker sh
/etc/supervisor/conf.d # ps -ef | grep php
 7 root  0:00 php /var/www/xxx.cn/artisan queue:work --queue=sendfile --tries=3 --daemon
 8 root  0:00 php /var/www/xxx.cn/artisan queue:work --queue=sendfile --tries=3 --daemon
 9 root  0:00 php /var/www/xxx.cn/artisan queue:work --queue=sendfile --tries=3 --daemon
 10 root  0:00 php /var/www/xxx.cn/artisan queue:work --queue=sendfile --tries=3 --daemon
 11 root  0:00 php /var/www/xxx.cn/artisan queue:work --queue=sendfile --tries=3 --daemon
 12 root  0:00 php /var/www/xxx.cn/artisan queue:work --queue=sendfile --tries=3 --daemon
 13 root  0:00 php /var/www/xxx.cn/artisan queue:work --queue=sendfile --tries=3 --daemon
 14 root  0:00 php /var/www/xxx.cn/artisan queue:work --queue=sendfile --tries=3 --daemon
 44 root  0:00 grep php

Laravel 多進程讀取隊列內容是否會重復

在 Laravel 的某個控制器方法,一次放入多個任務隊列:

public function index(Request $request)
{
 $this->dispatch((new SendFile3())->onQueue('sendfile'));
 $this->dispatch((new SendFile3())->onQueue('sendfile'));
 $this->dispatch((new SendFile3())->onQueue('sendfile'));
 $this->dispatch((new SendFile3())->onQueue('sendfile'));
 $this->dispatch((new SendFile3())->onQueue('sendfile'));
 $this->dispatch((new SendFile3())->onQueue('sendfile'));
 $this->dispatch((new SendFile3())->onQueue('sendfile'));
 $this->dispatch((new SendFile3())->onQueue('sendfile'));
 $this->dispatch((new SendFile3())->onQueue('sendfile'));
 $this->dispatch((new SendFile3())->onQueue('sendfile'));
 $this->dispatch((new SendFile3())->onQueue('sendfile'));
 $this->dispatch((new SendFile3())->onQueue('sendfile'));
 $this->dispatch((new SendFile3())->onQueue('sendfile'));
 $this->dispatch((new SendFile3())->onQueue('sendfile'));
 $this->dispatch((new SendFile3())->onQueue('sendfile'));
 $this->dispatch((new SendFile3())->onQueue('sendfile'));
 $this->dispatch((new SendFile3())->onQueue('sendfile'));
 $this->dispatch((new SendFile3())->onQueue('sendfile'));
}

在隊列處理的方法打印日志,打印處理的隊列的 ID:

app/Jobs/SendFile3.php

public function handle()
{
 info('invoke SendFile3');
 dump('invoke handle');
 $rawbody = $this->job->getRawBody();
 $info = json_decode($rawbody, true);
 info('queue id:' . $info['id']);
}

Laravel 使用 Redis 的 list 作為隊列的數據結構,并會為每個隊列分配一個 ID,數據結構如下:

{
 "job": "Illuminate\\Queue\\CallQueuedHandler@call",
 "data": {
 "commandName": "App\\Jobs\\SendFile3",
 "command": "O:18:\"App\\Jobs\\SendFile3\":4:{s:6:\"\u0000*\u0000job\";N;s:10:\"connection\";N;s:5:\"queue\";s:8:\"sendfile\";s:5:\"delay\";N;}"
 },
 "id": "hadBcy3IpNsnOofQQdHohsa451OkQs88",
 "attempts": 1
}

請求這個控制器路由(或者命令行方式),就可以看到 Redis 中多了很多隊列任務了,如圖:

這個時候開啟 Supervisor 處理隊列任務,并查看日志:

[2017-12-23 19:01:01] local.INFO: invoke SendFile3
[2017-12-23 19:01:01] local.INFO: invoke SendFile3
[2017-12-23 19:01:01] local.INFO: invoke SendFile3
[2017-12-23 19:01:01] local.INFO: invoke SendFile3
[2017-12-23 19:01:01] local.INFO: invoke SendFile3
[2017-12-23 19:01:01] local.INFO: invoke SendFile3
[2017-12-23 19:01:01] local.INFO: invoke SendFile3
[2017-12-23 19:01:01] local.INFO: invoke SendFile3
[2017-12-23 19:01:01] local.INFO: queue id:JaClJzhDEvntzLCRIz6uRQkCVLbE8Y9C
[2017-12-23 19:01:01] local.INFO: queue id:ukHv0Li4P2VgPa55qU6yEOJM27Mo5YwJ
[2017-12-23 19:01:01] local.INFO: queue id:ObMpwDTmnaveBUkU7aan5abt3Agyt90l
[2017-12-23 19:01:01] local.INFO: queue id:fo2qZn2ftSdQtdnKOciMK7iJb4qlhRGE
[2017-12-23 19:01:01] local.INFO: queue id:uLjFMoOU7Wk7bOAd4zpHb3ccRMJHBtR6
[2017-12-23 19:01:01] local.INFO: queue id:87ULqPBObFmGr16nl5wxFVOi71zGCeRM
[2017-12-23 19:01:01] local.INFO: queue id:9UVl0muQLzBqlRI99rChGW2ElXwVEMIE
[2017-12-23 19:01:01] local.INFO: queue id:a0vgyZuz9HtmH7DGHEpXqesFTcQU3QAF
[2017-12-23 19:01:01] local.INFO: invoke SendFile3
[2017-12-23 19:01:01] local.INFO: invoke SendFile3
[2017-12-23 19:01:01] local.INFO: queue id:2cXuXxopPkgYiV4WO8gv9CJ6CwXeKtYL
[2017-12-23 19:01:01] local.INFO: invoke SendFile3
[2017-12-23 19:01:01] local.INFO: queue id:9acTAYa8cxpJX6Q3Gb1sULokotP8reqZ
[2017-12-23 19:01:01] local.INFO: invoke SendFile3
[2017-12-23 19:01:01] local.INFO: invoke SendFile3
[2017-12-23 19:01:01] local.INFO: queue id:BPHQvBboChlv4gr2I0vyLVyw9bijtTYJ
[2017-12-23 19:01:01] local.INFO: invoke SendFile3
[2017-12-23 19:01:01] local.INFO: queue id:Fm6tNajdxYKtdQbDMYDmwWJFLnNikRyg
[2017-12-23 19:01:01] local.INFO: invoke SendFile3
[2017-12-23 19:01:01] local.INFO: queue id:nyAbcvSkBVPbaH3e2ItQkoLJlP1ficib
[2017-12-23 19:01:01] local.INFO: queue id:WBHsSVZtP43569UoPXxfLLJcvYmPW7cP
[2017-12-23 19:01:01] local.INFO: invoke SendFile3
[2017-12-23 19:01:01] local.INFO: queue id:bliPnKcRSDApwVmKLNxEhaKelhm0RDEY
[2017-12-23 19:01:01] local.INFO: invoke SendFile3
[2017-12-23 19:01:01] local.INFO: invoke SendFile3
[2017-12-23 19:01:01] local.INFO: queue id:eOAoQucEIwRz9uZ64xm6IDKgiqj9Xc3W
[2017-12-23 19:01:01] local.INFO: invoke SendFile3
[2017-12-23 19:01:01] local.INFO: queue id:lzise9EiqQqINrhALbmAI4qNg7qylpb2
[2017-12-23 19:01:01] local.INFO: invoke SendFile3
[2017-12-23 19:01:01] local.INFO: queue id:WXYKvcfOhS1pPnwOwUTsenoMv5l5EUXe
[2017-12-23 19:01:01] local.INFO: invoke SendFile3
[2017-12-23 19:01:01] local.INFO: queue id:XtH5JiwLgnrwWzI02Oyi70pihAOkuJUD
[2017-12-23 19:01:01] local.INFO: invoke SendFile3
[2017-12-23 19:01:01] local.INFO: invoke SendFile3
[2017-12-23 19:01:01] local.INFO: queue id:9ehmE5HImlpNubpY0xWN8UVrOzxeMqws
[2017-12-23 19:01:01] local.INFO: queue id:C1sK87cpZl47edLA0zhfo7PJ9MIEcoyx
[2017-12-23 19:01:01] local.INFO: invoke SendFile3
[2017-12-23 19:01:01] local.INFO: invoke SendFile3
[2017-12-23 19:01:01] local.INFO: invoke SendFile3
[2017-12-23 19:01:01] local.INFO: queue id:2kwl51oH4lyyRrljCReGUCkNiJRDl7oe
[2017-12-23 19:01:01] local.INFO: queue id:ObRpoqrYTPYiyv2delMlOXu3sAPpWJlN
[2017-12-23 19:01:01] local.INFO: invoke SendFile3
[2017-12-23 19:01:01] local.INFO: queue id:6qgu6W3TapLjSrt688yv9HRXvDDLxntz
[2017-12-23 19:01:01] local.INFO: queue id:wiTlERhwn7s9cQkfUF9lLlNADpXjKncI
[2017-12-23 19:01:01] local.INFO: invoke SendFile3
[2017-12-23 19:01:01] local.INFO: queue id:ZSLW0VLFBDpL4wjTJzu3Yb3V45pNe807
[2017-12-23 19:01:01] local.INFO: invoke SendFile3
[2017-12-23 19:01:01] local.INFO: queue id:qhZlXLGfGWRluIeNm7VbllmTJZYb2h5n
[2017-12-23 19:01:01] local.INFO: invoke SendFile3
[2017-12-23 19:01:01] local.INFO: queue id:LUx1IByD3L2psNl9BZwHhk2knXyRPzW6
[2017-12-23 19:01:01] local.INFO: invoke SendFile3
[2017-12-23 19:01:01] local.INFO: queue id:M2RESPjyo5hpAFxxL0EQbWwsUq4jpmWn
[2017-12-23 19:01:01] local.INFO: invoke SendFile3
[2017-12-23 19:01:01] local.INFO: invoke SendFile3
[2017-12-23 19:01:01] local.INFO: queue id:hUsGaiIAOO6ZfGQc5kGHGpsv5RpoRPYO
[2017-12-23 19:01:01] local.INFO: queue id:cEHJsOy6bLeZ4NbncPziaHqlarMeyyEF
[2017-12-23 19:01:01] local.INFO: invoke SendFile3
[2017-12-23 19:01:01] local.INFO: queue id:w4bkFiJKMU5saqG2xKN3ZRL5BYXGATMk
[2017-12-23 19:01:01] local.INFO: invoke SendFile3
[2017-12-23 19:01:01] local.INFO: queue id:0zBuwbxlrEhhxKfYBkVyTY4z35f154sI
[2017-12-23 19:01:01] local.INFO: queue id:mvoZvyDPvq4tcPjEy9G7PMtH3MwPkPik
[2017-12-23 19:01:01] local.INFO: invoke SendFile3
[2017-12-23 19:01:01] local.INFO: queue id:TLvF74eeidECWKtjZqWvW03UJTRPTL9r
[2017-12-23 19:01:01] local.INFO: queue id:me8wyPfgcz0nf9xvcXz0hf2xVxqa1FFS

這 8 個進程并發處理隊列,但從打印的日志看,沒有出現同樣的 ID. 我們再看一下 Laravel 如何使用 Redis 處理隊列的。

分析一下 Laravel 隊列的處理

Laravel 中入隊列方法

public function pushRaw($payload, $queue = null, array $options = [])
{
 $this->getConnection()->rpush($this->getQueue($queue), $payload);
 
 return Arr::get(json_decode($payload, true), 'id');
}

用的是 Redis 的 rpush 命令。

Laravel 中取隊列方法

public function pop($queue = null)
{
 $original = $queue ?: $this->default; 
 $queue = $this->getQueue($queue); 
 $this->migrateExpiredJobs($queue.':delayed', $queue); 
 if (! is_null($this->expire)) {
  $this->migrateExpiredJobs($queue.':reserved', $queue);
 } 
 list($job, $reserved) = $this->getConnection()->eval(
  LuaScripts::pop(), 2, $queue, $queue.':reserved', $this->getTime() + $this->expire
 ); 
 if ($reserved) {
  return new RedisJob($this->container, $this, $job, $reserved, $original);
 }
}

這里用的是 lua 腳本取隊列,如下:

public static function pop()
{
 return 'LUA'
local job = redis.call('lpop', KEYS[1])
local reserved = false
if(job ~= false) then
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;
}

那么結論是:從 Laravel 的處理方式和打印的日志結果看,即使多個進程讀取同一個隊列,也不會讀取到一樣的數據。

總結

以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作具有一定的參考學習價值,如果有疑問大家可以留言交流,謝謝大家對腳本之家的支持。

您可能感興趣的文章:
  • laravel中Redis隊列監聽中斷的分析
  • laravel使用Redis實現網站緩存讀取的方法詳解
  • Laravel如何使用Redis共享Session
  • laravel使用redis隊列實例講解

標簽:定西 六安 海南 迪慶 南寧 樂山 十堰 佛山

巨人網絡通訊聲明:本文標題《關于 Laravel Redis 多個進程同時取隊列問題詳解》,本文關鍵詞  關于,Laravel,Redis,多個,進程,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《關于 Laravel Redis 多個進程同時取隊列問題詳解》相關的同類信息!
  • 本頁收集關于關于 Laravel Redis 多個進程同時取隊列問題詳解的相關信息資訊供網民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    国产亚洲欧美激情| 国产一区二区三区蝌蚪| 欧美变态tickle挠乳网站| 国产精品一区二区免费不卡 | 欧美无人高清视频在线观看| 一本大道av一区二区在线播放| 麻豆精品国产传媒mv男同 | 日韩毛片视频在线看| 精品久久人人做人人爱| 1024成人网| 亚洲高清一区二区三区| 日韩黄色片在线观看| 另类欧美日韩国产在线| 国产成人在线视频网址| 欧美亚洲国产一卡| 欧美xxxxxxxx| 亚洲欧美日韩一区二区三区在线观看| 国产精品二区一区二区aⅴ污介绍| 精品福利av导航| 国产精品区一区二区三| 全国精品久久少妇| 国产在线精品一区二区夜色| 91美女在线观看| 国产欧美一区在线| 蜜臀91精品一区二区三区| 偷拍与自拍一区| 91丨九色丨黑人外教| 国产亚洲婷婷免费| 美国精品在线观看| 久久久av毛片精品| 亚洲大片在线观看| caoporn国产精品| 国产精品少妇自拍| 亚洲综合色噜噜狠狠| www.欧美.com| 亚洲乱码日产精品bd| 欧美色视频在线| 欧美a一区二区| 亚洲精品一区二区精华| 欧美天天综合网| 一区2区3区在线看| 日韩制服丝袜av| 国产九色精品成人porny| 欧美日韩国产不卡| 欧美日韩另类国产亚洲欧美一级| 中文字幕中文字幕在线一区| 日韩专区在线视频| 欧美亚洲高清一区二区三区不卡| 91麻豆国产精品久久| 91精品国产乱码久久蜜臀| 国产精品成人一区二区艾草| 日韩精品福利网| 日韩高清不卡在线| 亚洲色图.com| 五月激情丁香一区二区三区| 91丨国产丨九色丨pron| 久久一夜天堂av一区二区三区| 亚洲国产成人av网| 亚洲国产精品久久久久婷婷884| 中文字幕在线不卡视频| 欧美精品v日韩精品v韩国精品v| 一本色道a无线码一区v| 国产欧美日韩亚州综合| 美女脱光内衣内裤视频久久网站| 亚洲老司机在线| 久久久午夜精品理论片中文字幕| 91毛片在线观看| 亚洲视频一区在线观看| 日韩欧美高清dvd碟片| 久久精品亚洲国产奇米99| 久久精品视频在线免费观看| 亚洲美女偷拍久久| 热久久国产精品| 国产剧情在线观看一区二区| 国产麻豆视频一区二区| 日韩视频一区二区在线观看| 2020日本不卡一区二区视频| 一区二区三区四区乱视频| 五月综合激情婷婷六月色窝| 蜜臀国产一区二区三区在线播放 | 国产区在线观看成人精品| 中文字幕一区二区三区在线观看 | 亚洲福利国产精品| 色综合久久久久久久久久久| 欧美一区二区福利视频| 国产福利一区二区三区| 欧美乱妇一区二区三区不卡视频| 麻豆91精品视频| 在线免费观看一区| 国产一区视频在线看| 欧美性猛交一区二区三区精品| 蜜芽一区二区三区| 欧美亚洲国产一区二区三区va | 成人黄页在线观看| 久久精品这里都是精品| 91国偷自产一区二区开放时间 | www.欧美日韩| 中文字幕在线一区| 国产成人综合精品三级| 在线亚洲一区观看| 成人av电影在线| 美女网站在线免费欧美精品| 欧美日韩一区二区不卡| 欧美区一区二区三区| 国产综合久久久久影院| 91免费看`日韩一区二区| 日韩一二三四区| 91超碰这里只有精品国产| 极品少妇xxxx偷拍精品少妇| 国产亚洲一区二区三区四区| 日日夜夜精品视频免费| 亚洲欧洲日产国产综合网| 国产日韩欧美a| 国产欧美精品区一区二区三区 | 国产精品卡一卡二卡三| 亚洲成av人片在线| 亚洲18女电影在线观看| 亚洲色欲色欲www| 一区二区三区不卡在线观看| 日韩亚洲欧美成人一区| 在线成人免费视频| 亚洲第一福利一区| 久久天堂av综合合色蜜桃网| 日韩精品一区二区三区蜜臀| 国产91精品在线观看| 最近日韩中文字幕| 亚洲成av人片| 91影视在线播放| 亚洲欧美偷拍另类a∨色屁股| 中文字幕国产精品一区二区| 视频一区二区三区入口| 国产成人精品亚洲午夜麻豆| 亚洲二区在线视频| 国产麻豆成人精品| 欧美激情一区不卡| 一区二区三区日韩| 美女网站视频久久| av网站免费线看精品| 91在线观看地址| 国产成人综合亚洲91猫咪| 欧美日韩国产欧美日美国产精品| 91精品综合久久久久久| 亚洲免费在线视频一区 二区| 欧美另类videos死尸| 中文字幕一区日韩精品欧美| www久久久久| 精品视频一区三区九区| 亚洲视频香蕉人妖| 一区二区三区在线视频观看| 欧美日韩dvd在线观看| 欧美日韩一区三区四区| 337p亚洲精品色噜噜狠狠| 3d成人h动漫网站入口| 日韩中文字幕不卡| 亚洲与欧洲av电影| 日韩高清在线电影| 亚洲国产精品成人综合| 综合久久一区二区三区| 欧美日韩国产综合一区二区| 国产精品99久久久久久宅男| 亚洲一区二区av电影| 国产日韩av一区二区| 欧美精品少妇一区二区三区| 国产 欧美在线| 亚洲综合小说图片| 亚洲国产精品传媒在线观看| 欧美一卡在线观看| 色婷婷av一区二区三区大白胸| 欧美猛男男办公室激情| 99视频一区二区三区| 裸体健美xxxx欧美裸体表演| 一区二区三区中文在线观看| 久久久久久毛片| 欧美一级xxx| 在线不卡一区二区| 日韩va欧美va亚洲va久久| 中文字幕一区二区三区在线播放| 日韩国产欧美视频| 亚洲欧美综合色| 喷水一区二区三区| 久久久精品2019中文字幕之3| 一区免费观看视频| 蜜桃视频一区二区三区在线观看 | 国产成人综合亚洲网站| 欧美视频在线观看一区| 久久综合久久鬼色中文字| 3d动漫精品啪啪一区二区竹菊| 国产精品情趣视频| 久久众筹精品私拍模特| 一区二区三区在线视频免费| 91丝袜国产在线播放| 欧美一区午夜精品| 日本福利一区二区| 国产视频一区在线播放| 国产人妖乱国产精品人妖| 精品国产一区久久| 亚洲一区二区综合| 一区免费观看视频| 国产大陆a不卡| 国产成人在线观看|