当前位置 博文首页 > json_li的博客:Laravel5.5队列使用数据库驱动
更改.env配置
????????
要使用 database?队列驱动,你需要数据表保存任务信息。
要生成创建这些表的迁移,运行 Artisan 命令 queue:table,
迁移被创建之后,可以使用 migrate?命令生成这些表:
????????
执行完,修改和生成的文件
????????
php artisan migrate
????????
数据库生成表
????????
生成要执行的任务类
php artisan make:job QueueUser #你的任务文件名称
????????
生成任务文件
????????
编写队列处理
????????
php artisan config:clear #清除队列缓存
php artisan queue:work #开启队列
在任意控制器方法中测试调用
#延迟1分钟执行 若想延迟执行 去掉->delay(now()->addMinutes(1))即可
$job = (new QueueUser(['uid'=> 1, 'name'=>111]))->delay(now()->addMinutes(1));
dispatch($job);
数据库表 jobs
????????
等1分钟
在队列执行窗口 发现有动静
????????
再看数据库 执行完 数据库中那一条数据就删除了
????????
这就是使用数据库来异步去队列处理,有些业务比较复杂,耗时比较久的而又不需要即时出结果的可以使用异步去处理。
当然生产环境用就不能开个窗口去操作或者等待了,需要去有一个守护进程去监控,处理、重启。
cs