1、创建任务
默认情况下,应用程序的所有的可排队任务都被存储在了 app/Jobs 目录中。如果 app/Jobs 目录不存在,当您运行 make:job Artisan 命令时,将会自动创建该目录。您可以使用 Artisan CLI 来生成一个新的队列任务:
php artisan make:job ProcessPodcast
类结构:
<?php
namespace App\Jobs;
use Illuminate\Bus\Queueable;
use Illuminate\Contracts\Queue\ShouldQueue;
use Illuminate\Foundation\Bus\Dispatchable;
use Illuminate\Queue\InteractsWithQueue;
use Illuminate\Queue\SerializesModels;
class ProcessPodcast implements ShouldQueue {
use Dispatchable, InteractsWithQueue, Queueable, SerializesModels;
protected $args;
/**
* Create a new job instance.
*
* @return void
*/
public function __construct($args) {
$this->args = $args;
}
/**
* Execute the job.
*
* @return void
*/
public function handle() {
$args = $this->args;
// todo 处理相应逻辑。。。。。
}
}
2、分发任务
一旦编写了任务类,就可以使用任务本身的 dispatch
方法来分派它。传递给 dispatch
方法的参数将被传递给任务的构造函数:
<?php
namespace App\OpenApi\Controllers\API\V1;
use App\Jobs\ProcessPodcast;
use App\OpenApi\Controllers\BaseController;
use Illuminate\Http\Request;
class TestController extends BaseController {
/**
* @return void
*/
public function index(Request $request) {
$args = $request->all();
ProcessPodcast::dispatch($args);
}
}
3、执行队列监听
1)执行一个队列监听
开始队列监听:
php artisan queue:listen
你也可以在 listen 命令中使用逗号分隔的队列连接,来设置不同队列连接的优先层级:
php artisan queue:listen --queue=high,low
2)常驻队列处理器
在 queue:work 中也包含了一个 --daemon 选项,强迫队列处理器持续处理工作,而不会每次都重新启动框架,这个作法比起 queue:listen 可有效减少 CPU 使用量,但是却增加了布署时,对于处理中队列任务的复杂性。
要启动一个常驻的队列处理器,使用 --daemon:
php artisan queue:work connection --daemon
php artisan queue:work connection --daemon --sleep=3
php artisan queue:work connection --daemon --sleep=3 --tries=3
如你所见 queue:work 命令支持 queue:listen 大多相同的选项参数,你也可使用 php artisan help queue:work 命令来观看全部可用的选项参数。
Linux、Mac 常驻内存:
nohup php artisan queue:work --daemon