yiisoft/yii2-queue

支持DB、Redis、RabbitMQ、Beanstalk、SQS和Gearman的Yii2 Queue扩展

安装数: 7,700,648

依赖者: 161

建议者: 11

安全: 0

星标: 1,067

关注者: 77

分支: 296

开放问题: 66

类型:yii2-extension

2.3.7 2024-04-29 09:40 UTC

README

Yii2 Queue扩展


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

它支持基于 DBRedisRabbitMQAMQPBeanstalkActiveMQGearman 的队列。

文档位于 docs/guide/README.md

Latest Stable Version Total Downloads Build Status

安装

安装此扩展的最佳方式是通过 composer

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

基本用法

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

class DownloadJob extends BaseObject implements \yii\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

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

组件还具有跟踪推送到队列的作业状态的 Ability。

// 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);

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