1,安装laravel redis扩展
composer require predis/predis -vvv
2 配置redis
REDIS_HOST=192.168.0.110
REDIS_PASSWORD=aJEWARAWR
REDIS_PORT=6379
//队列连接
QUEUE_CONNECTION=redis
3 执行代码
php artisan make:job TestJob
3,模拟分发100个任务 队列名为 my_custom,这个在监听时需要
public function index(){
for ($i=0;$i<100;$i++){
//模拟分发100个任务
TestJob::dispatch("第".$i.'客户进入')->onQueue('my_custom');
}
}
4,监听队列
php artisan queue:work redis --queue=my_custom
5 执行任务
日志结果
指定任务最大尝试次数
php artisan queue:work --tries=3
但是,可以采用更细粒度的方法:定义任务类本身的最大尝试次数。如果在任务类上指定了最大尝试次数,它将优先于命令行上提供的值:
<?php
namespace App\Jobs;
class ProcessPodcast implements ShouldQueue
{
/**
* 任务可尝试的次数
*
* @var int
*/
public $tries = 5;
}
基于时间的 “尝试”#
除了定义任务失败前尝试的次数之外,还可以定义任务应该超时的时间。这允许在给定的时间范围内尝试任意次数的任务。要定义任务超时的时间,请在任务类中添加 retryUntil 方法:
<?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;
use Illuminate\Support\Facades\Log;
class TestJob implements ShouldQueue
{
use Dispatchable, InteractsWithQueue, Queueable, SerializesModels;
public $data;
/**
* Create a new job instance.
*
* @return void
*/
public function __construct($data)
{
//
$this->data = $data;
}
/**
* Execute the job.
*
* @return void
*/
public function handle()
{
//
Log::error($this->data);
}
/**
* 确定作业应该超时的时间 5秒后超时
*
* @return \DateTime
*/
public function retryUntil()
{
return now()->addSeconds(5);
}
}
最大异常数#
有时,你可能希望指定某个任务可尝试很多次,但如果重试次数超过了给定数量,触发了异常,则该任务应该失败。为了实现这一点,你可以在你的任务类中定义一个 maxExceptions 属性: