yii2-queue / up-to-php7
支持DB、Redis、RabbitMQ、Beanstalk、SQS和Gearman的Yii2 Queue扩展
2.3.0
2019-06-04 18:58 UTC
Requires
- php: >=5.5.0
- symfony/process: ^3.3||^4.0
- yiisoft/yii2: ~2.0.14
Requires (Dev)
- aws/aws-sdk-php: >=2.4
- enqueue/amqp-lib: ^0.8||^0.9.10
- enqueue/stomp: ^0.8.39
- jeremeamia/superclosure: *
- pda/pheanstalk: v3.*
- php-amqplib/php-amqplib: *
- phpunit/phpunit: ~4.4
- yiisoft/yii2-debug: *
- yiisoft/yii2-gii: *
- yiisoft/yii2-redis: *
Suggests
- ext-gearman: Need for Gearman queue.
- ext-pcntl: Need for process signals.
- aws/aws-sdk-php: Need for aws SQS.
- enqueue/amqp-lib: Need for AMQP interop queue.
- enqueue/stomp: Need for Stomp queue.
- pda/pheanstalk: Need for Beanstalk queue.
- php-amqplib/php-amqplib: Need for AMQP queue.
- yiisoft/yii2-redis: Need for Redis queue.
README
Yii2 Queue扩展
一个用于通过队列异步执行任务的扩展。
它支持基于DB、Redis、RabbitMQ、AMQP、Beanstalk、ActiveMQ和Gearman的队列。
文档位于docs/guide/README.md。
安装
安装此扩展的首选方式是通过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
有关特定于驱动程序的控制台命令及其选项的更多详细信息,请参阅文档。
该组件还具有跟踪推送到队列的作业状态的能力。
// 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);
有关更多详细信息,请参阅指南。