Yii2队列拓展 yii2-queue的配置使用

0.012字数 716阅读 3368

Yii2队列拓展 yii2-queue的配置使用

composer安装

php composer.phar require --prefer-dist yiisoft/yii2-queue

或者在composer.json添加:

"yiisoft/yii2-queue": "~2.0.0"

项目配置

注册queue组件,redis配置,queue配置以及指定queue的驱动方式为redis

return[

'bootstrap'=> [

'log',

'queue',

],

'components'=> [

'redis'=>[

'class'=>'yii\redis\Connection',

'hostname'=>'127.0.0.1',

'port'=>6379,

'database'=>0,

],

'queue'=> [

'class'=> \yii\queue\redis\Queue::class,

'redis'=>'redis',// Redis connection component or its config

'channel'=>'queue',// Queue channel key queue在redis中key的前缀

'as log'=> \yii\queue\LogBehavior::class,

],

];

使用queue

定义类:

需要被发送到队列的任务应该定义为一个类,集成自\yii\base\Object 实现\yii\queue\Job接口(必须实现execute方法,实现该任务的动作)

class MailJobextends \yii\base\Object implements\yii\queue\Job

{

public$subject='这是邮箱标题';

public$body='<br>
邮箱主体<br>
time:';

public$setTo= [];

public functionexecute($queue)

{

//队列实例需要执行的代码体

$mail= \Yii::$app->mailer->compose();

$mail->setTo($this->setTo);

$mail->setSubject($this->subject);

$this->body.= date('Y-m-d H:i:s',time());

//$mail->setTextBody('zheshisha ');  //发布纯文字文本

$mail->setHtmlBody($this->body);//发布可以带html标签的文本

if($mail->send())

echo"success";

else

echo"false";

//TODO: Implement execute() method.

}

}

操作队列:

//将作业推送到队列并获得其ID

$id= Yii::$app->queue->delay()->push(newMailJob([

'setTo'=>'xxxx@gmail.com',

]));

以下为获取该队列状态:

//这个作业等待执行。

Yii::$app->queue->isWaiting($id);

// Worker从队列获取作业,并执行它。

Yii::$app->queue->isReserved($id);

// Worker作业执行完成。

Yii::$app->queue->isDone($id);

控制台命令

控制台用于监听和处理队列任务。

yii queue/listen [wait]

listen命令启动一个守护进程,它可以无限查询队列。如果有新的任务,他们立即得到并执行。

wait是下一次查询队列的时间 当命令正确地通过supervisor来实现时,这种方法是最有效的。

yii queue/run

run命令获取并执行循环中的任务,直到队列为空。适用与cron

run与listen命令的参数:

--verbose,-v: 将执行状态输出到控制台。

--isolate: 详细模式执行作业。如果启用,将打印每个作业的执行结果。

--color: 高亮显示输出结果。

yii queue/info

info命令打印关于队列状态的信息。

执行 php yii queue/* 命令需要确保配置是在common中



业务可在crontab中建立定时执行该命令,即可按入队顺序执行脚本


https://github.com/yiisoft/yii2-queue

推荐阅读更多精彩内容

  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
  • Composer 基本用法 // 安装yii程序 composercreate-project--prefer-d...
  • Sites 网站 yiifeed:Yii 最新动态都在这里 yiigist:Yii 专用的 Packages my...
  • 安装YII2 在确保composer安装完成后通过composer安装YII2 第一条命令为全局安装一个js的包管...
  • 熵。 百度:在孤立系统中,体系与环境没有能量交换,体系总是自发地向混乱度增大的方向变化,总使整个系统的熵值...