婷婷综合国产,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
    亚洲精品国产精品乱码不99| 欧美军同video69gay| 韩国理伦片一区二区三区在线播放 | 成人福利电影精品一区二区在线观看| 国产精品综合一区二区三区| 成人黄色网址在线观看| 欧美三级电影网| √…a在线天堂一区| 日本不卡一区二区| 成年人午夜久久久| 欧美一区二区在线视频| 亚洲福利一二三区| 国产不卡视频一区| 91精品国产入口在线| 精品国产人成亚洲区| 亚洲成国产人片在线观看| 国产精品自拍在线| 欧美日本在线看| 久久日韩精品一区二区五区| 亚洲一区二区精品3399| 成人午夜免费av| 精品三级在线看| 亚洲综合自拍偷拍| 成人av手机在线观看| 久久久久国产免费免费 | 91欧美激情一区二区三区成人| 欧美日韩亚洲综合一区二区三区| 欧美经典一区二区| 麻豆精品精品国产自在97香蕉 | 成人综合婷婷国产精品久久蜜臀| 91精品欧美福利在线观看| 亚洲美女偷拍久久| 不卡视频一二三四| 91精品婷婷国产综合久久| 亚洲一区二区视频在线| 成人国产视频在线观看| 久久久精品免费免费| 国产成人久久精品77777最新版本 国产成人鲁色资源国产91色综 | 精品在线一区二区| 日韩亚洲欧美高清| 亚洲成a天堂v人片| 欧美三级日韩在线| 免费观看久久久4p| 91精品免费在线| 午夜激情久久久| 7777精品伊人久久久大香线蕉的 | 日韩欧美一二三四区| 亚洲国产精品久久艾草纯爱| 色吊一区二区三区| 亚洲一区二区三区四区的| 91精品欧美综合在线观看最新| 亚洲成人免费观看| 欧美日本高清视频在线观看| 亚洲国产欧美另类丝袜| 欧美大片在线观看| 国产精品中文有码| 中文字幕电影一区| eeuss鲁片一区二区三区在线观看| 国产精品狼人久久影院观看方式| 成人午夜私人影院| 亚洲综合色成人| 欧美videossexotv100| 国产一区二区中文字幕| 国产精品乱码人人做人人爱| 国产在线不卡一卡二卡三卡四卡| 亚洲精品在线观看视频| 国产大陆精品国产| 亚洲黄一区二区三区| 欧美色国产精品| 国产在线精品国自产拍免费| 日韩欧美中文字幕公布| 99久久99久久综合| 亚洲综合一区二区| 欧美成人r级一区二区三区| 日本视频一区二区| 国产精品麻豆一区二区| 欧美久久一二三四区| 国内精品久久久久影院薰衣草| 国产精品污污网站在线观看| 3d动漫精品啪啪一区二区竹菊| 国产一区二区三区四区在线观看| 中文av字幕一区| 9191久久久久久久久久久| proumb性欧美在线观看| av中文一区二区三区| 亚洲二区在线视频| 久久久精品tv| 欧美一区二区黄| 本田岬高潮一区二区三区| 亚洲成av人综合在线观看| 久久精品欧美日韩| 欧美在线一区二区三区| 免费在线观看成人| 亚洲激情男女视频| 国产欧美日韩三区| 欧美一二三区在线| 精品视频在线免费| 黄色日韩三级电影| 捆绑变态av一区二区三区| 17c精品麻豆一区二区免费| 日韩视频不卡中文| 不卡在线观看av| 日韩欧美国产麻豆| 在线观看日产精品| 欧美色区777第一页| 欧美亚洲一区二区在线观看| 91在线观看视频| 欧美综合色免费| 欧美中文字幕久久 | 国产成人午夜精品影院观看视频 | 极品美女销魂一区二区三区| 免费视频最近日韩| 看电视剧不卡顿的网站| 久久福利资源站| 国产一区二区调教| 成人ar影院免费观看视频| 成人美女视频在线看| 99久久国产综合精品色伊| 色一区在线观看| 欧美视频自拍偷拍| 欧美另类一区二区三区| 日韩一区二区三区免费看 | 日韩精品专区在线影院重磅| 欧美一区二区视频在线观看2020| 日韩西西人体444www| 精品国产乱码久久久久久影片| 久久奇米777| 亚洲伦在线观看| 亚洲超丰满肉感bbw| 日本va欧美va瓶| 国产精品亚洲а∨天堂免在线| 风间由美一区二区三区在线观看| 国产成人午夜视频| 欧美色图在线观看| 精品999久久久| 亚洲精品国产一区二区三区四区在线 | 久久久久久9999| 亚洲精品视频免费看| 亚洲第一主播视频| 国产九色精品成人porny | 国产一区二区三区在线观看免费视频 | 一区二区三区日韩精品视频| 亚洲国产视频一区二区| 狠狠色2019综合网| 色婷婷激情一区二区三区| 欧美一二三在线| 亚洲色欲色欲www| 青青草原综合久久大伊人精品| 国产·精品毛片| 欧美精品三级在线观看| 国产喂奶挤奶一区二区三区| 一个色综合av| 成人永久aaa| 欧美成人aa大片| 午夜精品久久久久久久| 成人动漫一区二区在线| 日韩亚洲电影在线| 亚洲国产日韩精品| 成人午夜短视频| 欧美大度的电影原声| 一区二区三区四区亚洲| 国产毛片精品视频| 制服丝袜中文字幕一区| 一区二区三区av电影 | 亚洲婷婷在线视频| 黄色日韩三级电影| 日韩视频一区二区三区| 亚洲自拍偷拍欧美| 91香蕉国产在线观看软件| 久久精品水蜜桃av综合天堂| 日本视频中文字幕一区二区三区| 日本丶国产丶欧美色综合| 久久一留热品黄| 免费精品视频最新在线| 欧美欧美欧美欧美首页| 亚洲一本大道在线| 欧美在线影院一区二区| 中文字幕佐山爱一区二区免费| 国产成人av在线影院| 久久―日本道色综合久久| 久久国产精品72免费观看| 日韩一级成人av| 日本不卡一区二区三区| 欧美日韩国产天堂| 亚洲第一av色| 日本韩国欧美国产| 亚洲精品你懂的| 色噜噜偷拍精品综合在线| 亚洲欧美怡红院| 91在线精品一区二区三区| 国产精品久久久久久一区二区三区| 国产精品一区二区在线观看网站| 精品国产一区二区国模嫣然| 激情偷乱视频一区二区三区| www国产成人| 成人中文字幕合集| 亚洲女与黑人做爰| 欧美性极品少妇| 日本午夜精品一区二区三区电影 | 久久国产精品99久久久久久老狼|