yii2 beanstalk異步隊(duì)列使用教程

安裝

linux安裝(window用戶我暫時(shí)沒有更好的方案,請安裝虛擬機(jī),我使用的是vagrant)

yum install beanstalk

yii2項(xiàng)目安裝

composer require udokmeci/yii2-beanstalk "dev-master"

安裝管理 Beanstalk 隊(duì)列的 Web 系統(tǒng),此項(xiàng)目是一個(gè)單獨(dú)的系統(tǒng)言疗,可以查看和管理隊(duì)列任務(wù)

composer create-project ptrofimov/beanstalk_console -s dev beanstalk_console

如何使用

首先诀艰,服務(wù)端開啟

beanstalkd -l 127.0.0.1 -p 11300

yii2 console 模塊中配置
main.php

'components' => [
    // ...
    'beanstalk' => [
        'class' => 'udokmeci\yii2beanstalk\Beanstalk',
        'host' => 127.0.0.1, // default host
        'port' => 11300,
        'connectTimeout' => 1,
        'sleep' => false, // or int for usleep after every job
    ],
    // ...
],
'controllerMap' => [
    'worker'=>[
        'class' => 'app\commands\WorkerController',
    ]
],

執(zhí)行隊(duì)列在 console\controllers\WorkerController 里面:

<?php
namespace app\commands;

use common\helpers\ObjectHelper;
use common\models\MongoTrack;
use common\services\TrackService;
use Pheanstalk\Job;
use udokmeci\yii2beanstalk\BeanstalkController;
use Yii;

class WorkerController extends BeanstalkController
{
    /**
     * @var integer 優(yōu)先級 值越小優(yōu)先級越高,默認(rèn)為1024
     */
    const DELAY_PRIORITY = 1000;

    /**
     * @var integer 延遲執(zhí)行的秒數(shù)
     */
    const DELAY_TIME = 5;

    /**
     * @var  integer 當(dāng) delay_max 達(dá)到 刪除或延遲
     */
    const DELAY_MAX = 3;

    public function listenTubes()
    {
        return ['tube', 'track'];
    }


    /**
     * 采集數(shù)據(jù)
     * @param $job Job
     * @return string
     */
    public function actionTrack($job)
    {
        /** @var object $sentData */
        $sentData = $job->getData();
        if (TrackService::isNeedTrack($sentData->unique_id, $sentData->source, $sentData->method)) {
            $model = new MongoTrack();
            $model->load(ObjectHelper::toArray($sentData), '');
            fwrite(STDOUT, json_encode($model->errors));
            if ($model->save()) {
                return self::DELETE;
            }
            fwrite(STDOUT, json_encode($model->errors));
            return self::BURY;
        }
        // 不需要保存 mongodb 刪除
        return self::DELETE;
    }

    // ...
}

然后執(zhí)行php yii worker

安裝管理 Beanstalk 隊(duì)列的 Web 系統(tǒng),此項(xiàng)目是一個(gè)單獨(dú)的系統(tǒng)黄绩,可以查看和管理隊(duì)列任務(wù)

composer create-project ptrofimov/beanstalk_console -s dev beanstalk_console

安裝完成后將域名指向beanstalk_console/public目錄下羡洁,可查看哥哥tube隊(duì)列狀態(tài)

Paste_Image.png

問題:linux 啟動進(jìn)程yii worker 進(jìn)程后,關(guān)閉xshell,如何保證進(jìn)程不關(guān)閉爽丹?有待探索

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末筑煮,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子粤蝎,更是在濱河造成了極大的恐慌真仲,老刑警劉巖,帶你破解...
    沈念sama閱讀 218,036評論 6 506
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件初澎,死亡現(xiàn)場離奇詭異秸应,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,046評論 3 395
  • 文/潘曉璐 我一進(jìn)店門软啼,熙熙樓的掌柜王于貴愁眉苦臉地迎上來桑谍,“玉大人,你說我怎么就攤上這事祸挪÷嗯” “怎么了?”我有些...
    開封第一講書人閱讀 164,411評論 0 354
  • 文/不壞的土叔 我叫張陵贿条,是天一觀的道長雹仿。 經(jīng)常有香客問我,道長闪唆,這世上最難降的妖魔是什么盅粪? 我笑而不...
    開封第一講書人閱讀 58,622評論 1 293
  • 正文 為了忘掉前任,我火速辦了婚禮悄蕾,結(jié)果婚禮上票顾,老公的妹妹穿的比我還像新娘。我一直安慰自己帆调,他們只是感情好奠骄,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,661評論 6 392
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著番刊,像睡著了一般含鳞。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上芹务,一...
    開封第一講書人閱讀 51,521評論 1 304
  • 那天蝉绷,我揣著相機(jī)與錄音,去河邊找鬼枣抱。 笑死熔吗,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的佳晶。 我是一名探鬼主播桅狠,決...
    沈念sama閱讀 40,288評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼轿秧!你這毒婦竟也來了中跌?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 39,200評論 0 276
  • 序言:老撾萬榮一對情侶失蹤菇篡,失蹤者是張志新(化名)和其女友劉穎漩符,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體驱还,經(jīng)...
    沈念sama閱讀 45,644評論 1 314
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡陨仅,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,837評論 3 336
  • 正文 我和宋清朗相戀三年津滞,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片灼伤。...
    茶點(diǎn)故事閱讀 39,953評論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡触徐,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出狐赡,到底是詐尸還是另有隱情撞鹉,我是刑警寧澤,帶...
    沈念sama閱讀 35,673評論 5 346
  • 正文 年R本政府宣布颖侄,位于F島的核電站鸟雏,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏览祖。R本人自食惡果不足惜孝鹊,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,281評論 3 329
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望展蒂。 院中可真熱鬧又活,春花似錦、人聲如沸锰悼。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,889評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽箕般。三九已至耐薯,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間丝里,已是汗流浹背曲初。 一陣腳步聲響...
    開封第一講書人閱讀 33,011評論 1 269
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留杯聚,地道東北人臼婆。 一個(gè)月前我還...
    沈念sama閱讀 48,119評論 3 370
  • 正文 我出身青樓,卻偏偏與公主長得像械媒,于是被迫代替她去往敵國和親目锭。 傳聞我的和親對象是個(gè)殘疾皇子评汰,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,901評論 2 355

推薦閱讀更多精彩內(nèi)容

  • Sites 網(wǎng)站 yiifeed:Yii 最新動態(tài)都在這里 yiigist:Yii 專用的 Packages my...
    guanguans閱讀 2,654評論 0 11
  • 1. Nginx的模塊與工作原理 Nginx由內(nèi)核和模塊組成纷捞,其中,內(nèi)核的設(shè)計(jì)非常微小和簡潔被去,完成的工作也非常簡單...
    rosekissyou閱讀 10,215評論 5 124
  • Spring Cloud為開發(fā)人員提供了快速構(gòu)建分布式系統(tǒng)中一些常見模式的工具(例如配置管理主儡,服務(wù)發(fā)現(xiàn),斷路器惨缆,智...
    卡卡羅2017閱讀 134,656評論 18 139
  • Composer Repositories Composer源 Firegento - Magento模塊Comp...
    零一間閱讀 3,960評論 1 66
  • 寶媽寶爸們糜值,大家好丰捷!今天和大家一起走進(jìn)《小熊寶寶繪本》(共15冊): 內(nèi)容簡介: 《小熊寶寶》這套繪本專為家里蹣跚...
    樂育匯閱讀 2,376評論 0 0