对列作用
队列的目的是将耗时的任务延时处理,比如发送邮件,从而大幅度缩短Web请求和相应的时间。
队列进程原理:写一个死循环的脚本在Linux系统持续运行,新的队列任务push到这个脚本中。
一、配置
队列 配置文件存放在config/queue.php 。在该文件中你将会找到框架自带的每一个队列驱动的连接配置,包括数据库、
Beanstalkd、 IronMQ、 Amazon SQS、 Redis 以及同步(本地使用)驱动。其中还包含了一个 null 队列驱动以拒绝队
列任务。默认是sync,即同步的,直接处理,无队列.要将其修改为对应的类型,如database等。
这次主要探讨 使用database 保存队列任务。
// 在.env 文件中修改:
QUEUE_DRIVER=database
// 清除配置缓存。这是个巨坑,测试时因为没执行这一步导致配置不生效,懵逼了许久
php artisan config:cache
二、依赖
1.数据库依赖:为了使用database 队列驱动,需要一张数据库表来存放任务,要生成创建该表的迁移,
运行 Artisan 命令queue:table ,迁移被创建好了之后,使用migrate 命令运行迁移:
php artisan queue:table
php artisan migrate
// 数据库会生成以下两张表:
jobs
migrations
2.其他队列类型依赖
下面是以上列出队列驱动需要安装的依赖:
• Amazon SQS: aws/aws-sdk-php ~3.0
• Beanstalkd: pda/pheanstalk ~3.0
• IronMQ: iron-io/iron_mq ~2.0
• Redis: predis/predis ~1.0
注意:
1、因为我使用两套环境(虚拟机、本地,两套环境共享项目目录),正常访问的是虚拟机的数据库。但使用 php artisan migrate
相关命令时报 2002 拒绝连接错误 ,因为在控制台访问到了本地的数据库。所以数据库配置:
DB_HOST=localhost
修改为 具体的ip:
DB_HOST=192.168.82.52
清除缓存:
php artisan config:cache
2、报错:SQLSTATE[42000]: 1071 Specified key was too long; max key length is 767 bytes
动配置迁移生成的默认字符串长度,你可以通过调用 AppServiceProvider 中的 Schema::defaultStringLength 方法来配置它。
局部配置:在报错的迁移脚本中加 Schema::defaultStringLength(191);
全局配置:在AppProvidersAppServiceProvider 的boot方法加Schema::defaultStringLength(191);
三、生成任务类
1、通常,所有的任务类都保存在 app/Jobs 目录.如果 app/Jobs 不存在,在运行 Artisan 命令 make:job 的时候,
它将会自动创建。你可以通过 Artisan CLI 来生成队列任务类:
php artisan make:job queueTest
生成的类 queueTest 都实现了 IlluminateContractsQueueShouldQueue 接口,
告诉 Laravel 将该任务推送到队列,而不是立即运行。
2、在 queueTest.php 的代码如下:
public function handle()
{
sleep(5);
Zhang::insert([ 'name' => 'queue.' . time() .uniqid(), 'time' => time()]);
}
// 在TestController.php 控制器的推送任务如下:
public function queueTest()
{
for($i = 0; $i < 100; $i ++) {
dispatch(new queueTest("ssss".$i));
}
exit('程序结束');
}
// routes添加路由:
Route::get('/queue', 'TestController@queue' );
四、启动队列监听
基本命令:
php artisan queue:listen //监听队列请求,只要运行着,就能一直接受请求,除非手动终止;
其他类型的监听、守护进程请参考顶部资料。
五、测试成功
在浏览器开几个窗口同时访问该地址:localhost/queue , 出现以下情况说明队列任务推送成功:
1、访问后,浏览器立即打印 '程序结束' ,说明任务已经压入队列;
2、进入数据库查看jods表,会发现很多还没执行完的任务;
3、在控制台会监听到正在运行的进程:
[2018-01-03 11:53:46] Processing: AppJobsqueueTest
[2018-01-03 11:53:56] Processed: AppJobsqueueTest
[2018-01-03 11:53:57] Processing: AppJobsqueueTest
总结
以上只是对laravel队列的一些基于database的基础运用,队列的知识远远不止这些。如果你有好的例子分享,欢迎留言。