Laravel5.5队列使用数据库驱动

版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/json_ligege/article/details/90443387

更改.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分钟

在队列执行窗口 发现有动静

        

再看数据库 执行完 数据库中那一条数据就删除了

        

这就是使用数据库来异步去队列处理,有些业务比较复杂,耗时比较久的而又不需要即时出结果的可以使用异步去处理。

当然生产环境用就不能开个窗口去操作或者等待了,需要去有一个守护进程去监控,处理、重启。

展开阅读全文

没有更多推荐了,返回首页