factorenergia/yii2-queue

支持数据库、Redis、RabbitMQ、Beanstalk、SQS和Gearman的Yii2 Queue扩展

安装数: 6,126

依赖: 0

建议者: 0

安全: 0

星标: 0

关注者: 1

分支: 295

开放问题: 0

类型:yii2-extension

2.2.0 2019-02-21 10:33 UTC

README

Yii2 Queue扩展


一个用于通过队列异步运行任务的扩展。

它支持基于 DBRedisRabbitMQAMQPBeanstalkGearman 的队列。

文档位于 docs/guide/README.md

Latest Stable Version Total Downloads Build Status

安装

安装此扩展的首选方法是使用 composer

运行

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

"factorenergia/yii2-queue": "~2.0"

将以下内容添加到您的 composer.json 文件的 require 部分。

基本用法

发送到队列的每个任务都应该定义为单独的类。例如,如果您需要下载并保存文件,类可能如下所示

class DownloadJob extends BaseObject implements \factorenergia\queue\JobInterface
{
    public $url;
    public $file;
    
    public function execute($queue)
    {
        file_put_contents($this->file, file_get_contents($this->url));
    }
}

以下是向队列发送任务的方式

Yii::$app->queue->push(new DownloadJob([
    'url' => 'http://example.com/image.jpg',
    'file' => '/tmp/image.jpg',
]));

将作业推入队列,该作业应在5分钟后运行

Yii::$app->queue->delay(5 * 60)->push(new DownloadJob([
    'url' => 'http://example.com/image.jpg',
    'file' => '/tmp/image.jpg',
]));

任务的确切执行方式取决于所使用的驱动程序。大多数驱动程序都可以使用控制台命令运行,该组件会自动在您的应用程序中注册这些命令。

此命令将循环获取和执行任务,直到队列空为止

yii queue/run

此命令启动一个守护进程,该守护进程无限期地查询队列

yii queue/listen

有关特定驱动程序的控制台命令及其选项的详细信息,请参阅文档。

该组件还具有跟踪已推入队列的作业状态的 capability。

// Push a job into the queue and get a message ID.
$id = Yii::$app->queue->push(new SomeJob());

// Check whether the job is waiting for execution.
Yii::$app->queue->isWaiting($id);

// Check whether a worker got the job from the queue and executes it.
Yii::$app->queue->isReserved($id);

// Check whether a worker has executed the job.
Yii::$app->queue->isDone($id);

有关更多详细信息,请参阅 指南