您好,登錄后才能下訂單哦!
本篇內容主要講解“Beanstalkd隊列的使用方法”,感興趣的朋友不妨來看看。本文介紹的方法操作簡單快捷,實用性強。下面就讓小編來帶大家學習“Beanstalkd隊列的使用方法”吧!
官網:https://kr.github.io/beanstalkd/
安裝(也可以采用composer進行安裝)
yum install beanstalkd --enablerepo=epel 或者 composer require pda/pheanstalk
1
啟動(0.0.0.0可以運行任何ip進行連接)
/usr/bin/beanstalkd -l 0.0.0.0 -p 11300 -b /var/lib/beanstalkd/binlog -F
-b 開啟binlog,斷電后重啟會自動恢復任務。
1
配置文件
/etc/sysconfig/beanstalkd
1
Beanstalkd設計里面的核心概念:
job:一個需要異步處理的任務,是 Beanstalkd 中的基本單元,需要放在一個 tube 中。
tube:一個有名的任務隊列,用來存儲統一類型的 job,是 producer 和 consumer 操作的對象。
producer:Job 的生產者,通過 put 命令來將一個 job 放到一個 tube 中。
consumer:Job的消費者,通過 reserve/release/bury/delete 命令來獲取 job 或改變 job 的狀態。
job 的生命周期
當producer直接put一個job時,job就處于READY狀態,等待consumer來處理,如果選擇延遲put,job就先到DELAYED狀態,等待時間過后才遷移到READY狀態。
consumer獲取了當前READY的job后,該job的狀態就遷移到RESERVED,這樣其他的consumer就不能再操作該job。當consumer完成該job后,可以選擇delete, release或者bury操作;delete之后,job從系統消亡,之后不能再獲取;release操作可以重新把該job狀態遷移回READY(也可以延遲該狀態遷移操作),使其他的consumer可以繼續獲取和執行該job;有意思的是bury操作,可以把該job休眠,等到需要的時候,再將休眠的job kick回READY狀態,也可以delete BURIED狀態的job。
正是有這些有趣的操作和狀態,才可以基于此做出很多意思的應用,比如要實現一個循環隊列,就可以將RESERVED狀態的job休眠掉,等沒有READY狀態的job時再將BURIED狀態的job一次性kick回READY狀態。
READY - 需要立即處理的任務,當延時 (DELAYED) 任務到期后會自動成為當前任務;
DELAYED - 延遲執行的任務, 當消費者處理任務后, 可以用將消息再次放回 DELAYED 隊列延遲執行;
RESERVED - 已經被消費者獲取, 正在執行的任務。Beanstalkd 負責檢查任務是否在 TTR(time-to-run) 內完成;
BURIED - 保留的任務: 任務不會被執行,也不會消失,除非有人把它 “踢” 回隊列;
DELETED - 消息被徹底刪除。Beanstalkd 不再維持這些消息。
優先級
任務 (job) 可以有 0~2^32 個優先級, 0 代表最高優先級,默認優先級為1024。
持久化
可以通過binlog將job及其狀態記錄到文件里面,在Beanstalkd下次啟動時可以通過讀取binlog來恢復之前的job及狀態。
分布式容錯
分布式設計和Memcached類似,beanstalkd各個server之間并不知道彼此的存在,都是通過client來實現分布式以及根據tube名稱去特定server獲取job。
超時控制
為了防止某個consumer長時間占用任務但不能處理的情況,Beanstalkd為reserve操作設置了timeout時間,如果該consumer不能在指定時間內完成job,job將被遷移回READY狀態,供其他consumer執行。
項目地址:https://github.com/pda/pheanstalk/
Producer 示例:向隊列中添加job
$pheanstalk = new Pheanstalk_Pheanstalk('127.0.0.1'); $pheanstalk ->useTube('tubeName') ->put($jobData);
Consumer 示例:從隊列中取出job
$job = $pheanstalk ->watch('tubeName') ->ignore('default') ->reserve(); echo $job->getData(); $pheanstalk->delete($job);
檢查服務狀態
$isAlive = $pheanstalk->getConnection()->isServiceListening(); //返回 true 或 false 4、獲取某一 tube 的數據 try{ $tubeStatus = $pheanstalk->statsTube('tubeName'); } catch (Exception $e){ if($e->getMessage()=='Server reported NOT_FOUND'){ //tube 不存在 $current_jobs_ready = 0; } }
到此,相信大家對“Beanstalkd隊列的使用方法”有了更深的了解,不妨來實際操作一番吧!這里是億速云網站,更多相關內容可以進入相關頻道進行查詢,關注我們,繼續學習!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。