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

    xiaoxiao2022-07-03  108

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

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

            

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

            

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

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

    最新回复(0)