0

0

Laravel中如何使用消息队列Queue_Laravel异步任务队列配置与运行【实战】

裘德小鎮的故事

裘德小鎮的故事

发布时间:2026-01-21 11:36:14

|

661人浏览过

|

来源于php中文网

原创

Laravel队列需手动配置驱动、创建任务类、分发任务并持续运行queue:work进程;开发用database驱动,生产首选redis;任务类须实现ShouldQueue接口、构造函数只存依赖、耗时操作放handle();dispatch()后需显式设置delay()、onQueue()和tries;queue:work必须由Supervisor等进程管理器常驻守护,且代码更新后需手动重启worker。

laravel中如何使用消息队列queue_laravel异步任务队列配置与运行【实战】

直接说结论: Laravel 队列不是“开箱即用”的异步魔法,它需要你明确选择驱动、创建任务类、分发任务,并**持续运行一个独立的 queue:work 进程**——漏掉任何一环,任务就只会堆在数据库或 Redis 里,永远不会执行。

怎么选队列驱动?别被文档带偏

开发阶段用 database 最省事,但别在生产环境用它扛流量;redis 是绝大多数项目的实际首选,性能高、支持延迟、重试、优先级队列都原生可用。

  • database:只需两行命令,适合本地验证逻辑是否走队列
    php artisan queue:table
    php artisan migrate
    然后改 .envQUEUE_CONNECTION=database
  • redis:确保已装 predis/prediscomposer require predis/predis),再改 .envQUEUE_CONNECTION=redis;Redis 连接参数(REDIS_HOST 等)必须和 config/database.php 中一致,否则 queue:work 启动就报 “Connection refused”
  • 千万别用 sync 上生产——它只是“假装”进队列,实际还是同步执行,handle() 一卡,整个 HTTP 请求就卡死

任务类怎么写?重点不是逻辑,是接口和构造函数

生成命令是 php artisan make:job SendWelcomeEmail,但关键不在名字,而在三件事:实现 ShouldQueue 接口、把依赖存进属性、别在 __construct 里做耗时操作。

  • 必须实现 ShouldQueue 接口,否则 dispatch() 不会进队列,而是立刻同步执行
  • 所有外部数据(比如 $user)必须通过构造函数传入并赋值给属性,不能在 handle() 里现场查库——因为任务可能几小时后才执行,模型可能已失效
  • 避免在 __construct 中调用 Mail::raw()Storage::put(),这些操作应严格放在 handle()

正确示例(简化):

虎课网
虎课网

虎课网是超过1800万用户信赖的自学平台,拥有海量设计、绘画、摄影、办公软件、职业技能等优质的高清教程视频,用户可以根据行业和兴趣爱好,自主选择学习内容,每天免费学习一个...

下载
class SendWelcomeEmail implements ShouldQueue
{
    use Dispatchable, InteractsWithQueue, Queueable, SerializesModels;

    protected $user;

    public function __construct($user)
    {
        $this->user = $user; // 只存,不操作
    }

    public function handle()
    {
        Mail::to($this->user['email'])->send(new WelcomeMail()); // 执行放这里
    }
}

任务怎么发?dispatch() 不是万能的,延迟和队列名得手动加

SendWelcomeEmail::dispatch($user) 是最常用写法,但它默认走 default 队列、无延迟、无限重试。真实业务中这三者几乎都要调整。

  • 延迟执行:用 delay(),参数是 DateTimeInterface,别传秒数——->delay(now()->addMinutes(5)) ✅,->delay(300) ❌(Laravel 9+ 已弃用整数秒)
  • 指定队列名:用 onQueue('emails'),这样你可以为邮件、短信、通知分别起不同队列,再用 Supervisor 起多个 queue:work 进程按需消费,避免低优任务挤占高优资源
  • 控制重试:在 Job 类里加 public $tries = 3;,或启动 worker 时加 --tries=3;没设的话默认无限重试,失败任务会一直卡在 jobs 表里占位

怎么让任务真正跑起来?queue:work 必须常驻,且不能裸跑

只在终端敲一次 php artisan queue:work,关掉终端或 SSH 断连,进程就死了——任务永远不执行。生产环境必须用进程管理器守护。

  • 开发调试可临时用:php artisan queue:work --once(只处理一个任务就退出),方便断点调试 handle()
  • 生产环境必须配 Supervisor,核心配置项不能少:autorestart=true(崩溃自动拉起)、numprocs=4(起 4 个 worker 并行)、--tries=3 --timeout=60(防单任务卡死)
  • 别用 queue:listen:它是旧版命令,性能差、不支持 Redis 的阻塞读,官方已弃用多年

最容易被忽略的一点:queue:work 进程启动后,**不会自动感知代码更新**。改了 handle() 方法?必须手动 supervisorctl restart laravel-worker: 或 kill 进程重启,否则跑的还是旧逻辑。

相关专题

更多
php文件怎么打开
php文件怎么打开

打开php文件步骤:1、选择文本编辑器;2、在选择的文本编辑器中,创建一个新的文件,并将其保存为.php文件;3、在创建的PHP文件中,编写PHP代码;4、要在本地计算机上运行PHP文件,需要设置一个服务器环境;5、安装服务器环境后,需要将PHP文件放入服务器目录中;6、一旦将PHP文件放入服务器目录中,就可以通过浏览器来运行它。

2708

2023.09.01

php怎么取出数组的前几个元素
php怎么取出数组的前几个元素

取出php数组的前几个元素的方法有使用array_slice()函数、使用array_splice()函数、使用循环遍历、使用array_slice()函数和array_values()函数等。本专题为大家提供php数组相关的文章、下载、课程内容,供大家免费下载体验。

1668

2023.10.11

php反序列化失败怎么办
php反序列化失败怎么办

php反序列化失败的解决办法检查序列化数据。检查类定义、检查错误日志、更新PHP版本和应用安全措施等。本专题为大家提供php反序列化相关的文章、下载、课程内容,供大家免费下载体验。

1527

2023.10.11

php怎么连接mssql数据库
php怎么连接mssql数据库

连接方法:1、通过mssql_系列函数;2、通过sqlsrv_系列函数;3、通过odbc方式连接;4、通过PDO方式;5、通过COM方式连接。想了解php怎么连接mssql数据库的详细内容,可以访问下面的文章。

974

2023.10.23

php连接mssql数据库的方法
php连接mssql数据库的方法

php连接mssql数据库的方法有使用PHP的MSSQL扩展、使用PDO等。想了解更多php连接mssql数据库相关内容,可以阅读本专题下面的文章。

1444

2023.10.23

html怎么上传
html怎么上传

html通过使用HTML表单、JavaScript和PHP上传。更多关于html的问题详细请看本专题下面的文章。php中文网欢迎大家前来学习。

1235

2023.11.03

PHP出现乱码怎么解决
PHP出现乱码怎么解决

PHP出现乱码可以通过修改PHP文件头部的字符编码设置、检查PHP文件的编码格式、检查数据库连接设置和检查HTML页面的字符编码设置来解决。更多关于php乱码的问题详情请看本专题下面的文章。php中文网欢迎大家前来学习。

1529

2023.11.09

php文件怎么在手机上打开
php文件怎么在手机上打开

php文件在手机上打开需要在手机上搭建一个能够运行php的服务器环境,并将php文件上传到服务器上。再在手机上的浏览器中输入服务器的IP地址或域名,加上php文件的路径,即可打开php文件并查看其内容。更多关于php相关问题,详情请看本专题下面的文章。php中文网欢迎大家前来学习。

1307

2023.11.13

Python GraphQL API 开发实战
Python GraphQL API 开发实战

本专题系统讲解 Python 在 GraphQL API 开发中的实际应用,涵盖 GraphQL 基础概念、Schema 设计、Query 与 Mutation 实现、权限控制、分页与性能优化,以及与现有 REST 服务和数据库的整合方式。通过完整示例,帮助学习者掌握 使用 Python 构建高扩展性、前后端协作友好的 GraphQL 接口服务,适用于中大型应用与复杂数据查询场景。

1

2026.01.21

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
PHP课程
PHP课程

共137课时 | 9万人学习

JavaScript ES5基础线上课程教学
JavaScript ES5基础线上课程教学

共6课时 | 9万人学习

PHP新手语法线上课程教学
PHP新手语法线上课程教学

共13课时 | 0.9万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号