Laravel队列系统通过配置驱动、创建任务和启动监听实现异步处理。首先在.env中设置QUEUE_CONNECTION选择database或redis等驱动,database需运行php artisan queue:table和migrate生成数据表;redis需配置正确连接信息。接着用php artisan make:job创建任务类,在handle方法编写逻辑,并通过ProcessPodcast::dispatch($podcast)分发任务,支持delay延迟执行。最后运行php artisan queue:work启动监听器处理任务,生产环境应使用Supervisor守护进程确保持续运行。

Laravel 的队列系统能让你把耗时任务(比如发送邮件、处理图片)放到后台执行,避免用户在前端长时间等待。实现的核心就是“配置驱动 + 创建任务 + 启动监听”。
配置队列驱动
第一步是告诉 Laravel 你的任务要存到哪里。这通过修改 .env 文件来完成。
-
database:适合小型项目或没有 Redis 环境的情况。设置
QUEUE_CONNECTION=database后,需要创建一张表来存储任务。 -
redis:性能更好,适合高并发场景。设置
QUEUE_CONNECTION=redis,并确保 .env 文件里的REDIS_HOST、REDIS_PORT等信息正确。 - sync:这是默认值,任务会立即同步执行,一般只用于开发调试。
选了 database 驱动后,运行以下命令生成迁移文件并创建数据表:
php artisan queue:tablephp artisan migrate
创建和分发任务
使用 Artisan 命令创建一个队列任务类,它会自动放在 app/Jobs 目录下。
php artisan make:job ProcessPodcast打开生成的 ProcessPodcast.php 文件,在 handle() 方法里写你的业务逻辑,比如处理音频文件。
在控制器或其他地方,用 dispatch() 方法把任务推送到队列:
你还可以链式调用方法控制任务行为,比如延迟执行:ProcessPodcast::dispatch($podcast)->delay(now()->addMinutes(10));
启动队列监听器
任务已经进队了,现在需要一个“工人”去处理它。运行下面的命令启动监听:
php artisan queue:work这个命令会持续运行,直到手动停止或遇到致命错误。它不会重新加载代码,所以修改代码后需要手动重启。
在生产环境,不能靠手动运行。要用 Supervisor 这样的进程管理工具,确保队列进程一直存活,并在崩溃后自动重启。Supervisor 的配置文件指向 php artisan queue:work 命令即可。
基本上就这些。配置好驱动,把任务 dispatch 出去,再用 queue:work 或 Supervisor 跑起来,队列就能正常工作了。










