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 文件来完成。
QUEUE_CONNECTION=database 后,需要创建一张表来存储任务。QUEUE_CONNECTION=redis,并确保 .env 文件里的 REDIS_HOST、REDIS_PORT 等信息正确。选了 database 驱动后,运行以下命令生成迁移文件并创建数据表:
php artisan queue:table使用 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 跑起来,队列就能正常工作了。
以上就是Laravel队列如何实现_Laravel框架消息队列配置与使用的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号