sync
, database
, beanstalkd
, sqs
, redis
,本例使用redis
作为队列服务,需先配置好Redis
服务。connections
中已经默认定义了redis
的连接:"redis" => [ "driver"=> "redis", "connection" => "default", "queue"=> "default", "expire"=> 60,],在.env环境配置文件中把默认的队列驱动改成
redis
:QUEUE_DRIVER=redis为了避免配置缓存的影响,执行以下命令清除并重建配置缓存:
php artisan config:cache2.新建Queueable Jobs
php artisan make:job MyJob新建一个名为MyJob的队列处理类,在
App/Jobs
目录下自动生成一个MyJob.php文件。
MyJob.php需要实现handle
方法,用来具体执行队列任务,构造函数可以用来传递需要的参数,handle
方法支持依赖注入。
这里handle
方法随便写了一个,就是往一个list
类型数据结构中存一个key-value
数据,测试消费队列的时候有没有起作用,构造函数传两个参数就是key
和value
.
<?phpnamespace AppJobs;use AppJobsJob;use IlluminateQueueSerializesModels;use IlluminateQueueInteractsWithQueue;use IlluminateContractsQueueShouldQueue;use IlluminateSupportFacadesRedis;class MyJob extends Job implements ShouldQueue{ use InteractsWithQueue, SerializesModels; private $key; private $value; /*** Create a new job instance.** @return void*/ public function __construct($key, $value) {$this->key = $key;$this->value = $value; } /*** Execute the job.** @return void*/ public function handle() {Redis::hset("queue.test", $this->key, $this->value); } public function failed() {dump("failed"); }}在控制器中使用
dispatch
方法调用队列,将任务放入队列中,控制器中写个方法如public function test()
,new MyJob
的构造函数传两个随机生成的字符串参数:$queueId = $this->dispatch(new MyJob("key_".str_random(4), str_random(10)));dd($queueId);配置并访问路由,可以多访问几次,然后到
Redis
中查看,会发现把队列存入了一个queue::queue:default
的List
结构中:
其中value
内容如下,这是转换成json
格式的,而实际上是经过序列号的字符串:
{ "job": "Illuminate\Queue\CallQueuedHandler@call", "data": {"command": "O:14:"App\Jobs\MyJob":6:{s:19:"u0000App\Jobs\MyJobu0000key";i:1;s:21:"u0000App\Jobs\MyJobu0000value";i:2;s:10:"connection";N;s:5:"queue";N;s:5:"delay";N;s:6:"u0000*u0000job";N;}" }, "id": "EV2bhqUlx0T8pRCVHw1qT0fkP8AQcyI8", "attempts": 1}这里
data
参数里包含了队列服务Job
的名称,构造函数的参数等信息,消费者执行任务的依据。attempts
表示重试的次数,往往执行队列任务失败了会重试,可以设置最多尝试次数。php artisan queue:listen这个命令,Laravel就开始消费队列。
可以看到这几个任务以此被消费,再去Redis
看看有没有实现预期要达到的效果,每个任务往一个List
类型的结构写入数据。
这证明队列任务消费成功。
总结
本文的内容到这就结束了,当然,还有更多Laravel队列的用法,可以请大家继续参考官方手册。希望本文的内容对大家学习Laravel有所帮助。