0

0

如何使用Laravel Reverb替代Pusher实现WebSocket通信? (自托管方案)

裘德小鎮的故事

裘德小鎮的故事

发布时间:2026-01-12 12:57:57

|

947人浏览过

|

来源于php中文网

原创

reverb 能直接替代 pusher 客户端逻辑,因其完全兼容 pusher 协议与 sdk 行为,前端只需修改连接参数(如 wshost、wsport、authendpoint)并保持 new pusher(...) 初始化方式即可无缝对接。

如何使用laravel reverb替代pusher实现websocket通信? (自托管方案)

为什么 Reverb 能直接替代 Pusher 的客户端逻辑

Reverb 是 Laravel 官方推出的自托管 WebSocket 服务器,它完全兼容 Pusher 的 WebSocket 协议和客户端 SDK 行为。这意味着你不需要重写前端 Pusher 实例初始化代码,只需改掉 keywsHostwsPort 等连接参数,就能让现有 pusher-js 无缝对接 Reverb 服务。

关键前提是:Reverb 启动后默认暴露与 Pusher 兼容的 WebSocket 接口(/app/{key}),且支持 ws://wss://,也支持 TLS 终止后的代理转发(如 Nginx)。

  • 前端仍用 new Pusher(...),但 cluster 字段可留空或设为任意值(Reverb 不校验 cluster)
  • authEndpoint 必须指向你的 Laravel 应用中带 reverb:auth 中间件的路由(如 /api/broadcasting/auth
  • 确保 BROADCAST_CONNECTION=reverb 已在 .env 中设置,否则 Laravel 广播事件不会发往 Reverb

如何配置 Reverb 服务端并启动

Reverb 不依赖 Redis Pub/Sub 做消息中转(它自己就是广播总线),但需要 Redis 存储连接元数据和认证状态。安装后必须显式运行 php artisan reverb:start 启动独立进程 —— 这不是 Artisan 命令行工具,而是一个常驻的 Swoole 服务器。

常见疏漏点:

  • REVERB_HOSTREVERB_PORT 必须与前端连接地址一致;若走 Nginx 反代,REVERB_HOST 应设为 0.0.0.0,Nginx 配置 proxy_pass http://127.0.0.1:8000(假设 Reverb 监听 8000)
  • REVERB_SSL_CERTREVERB_SSL_KEY 仅在启用 wss:// 时需要;若由 Nginx 终止 TLS,则 Reverb 只需监听 ws://(即不填这两个变量)
  • 务必执行 php artisan vendor:publish --tag=reverb-config 生成 config/reverb.php,否则 reverb:start 会因缺少配置失败

前端 Pusher 初始化要改哪些参数

原 Pusher 初始化通常类似:

const pusher = new Pusher('app-key', {
  cluster: 'mt1',
  encrypted: true,
});

换成 Reverb 后,核心变化是去掉 cluster、显式指定 host/port、关闭加密自动协商(因为 wss/ws 由你控制):

Gatekeep
Gatekeep

Gatekeep AI是一个专注于将文本转化为教学视频的智能教学工具,主要用于数学和物理等学科的教育。

下载
const pusher = new Pusher('your-reverb-app-key', {
  wsHost: 'your-domain.com',
  wsPort: 6001,
  wssPort: 6001,
  forceTLS: true, // 若 Nginx 终止 TLS,这里设 true;若 Reverb 自己跑 wss,则也设 true
  disableStats: true,
  authEndpoint: '/api/broadcasting/auth',
});

注意:wsPortwssPort 数值相同是允许的,forceTLS 为 true 时,pusher-js 会自动用 wss:// 协议连接。

  • your-reverb-app-key 必须与 config/broadcasting.phpreverb 驱动的 key 一致
  • authEndpoint 返回的响应格式必须严格符合 Pusher 协议({ "auth": "xxx:xxx" }),Reverb 的 reverb:auth 中间件已内置该逻辑
  • 浏览器WebSocket connection to 'wss://...' failed,优先检查 Nginx 是否透传了 UpgradeConnection

如何验证 Reverb 是否正常收发事件

最直接的方式是用 php artisan tinker 手动触发一个广播事件,同时用浏览器开发者工具的 Network → WS 标签观察连接状态和消息收发。

例如,定义一个测试事件:

class TestEvent implements ShouldBroadcast
{
    use Dispatchable, InteractsWithSockets, SerializesModels;

    public function broadcastOn(): array
    {
        return [new Channel('test-channel')];
    }

    public function broadcastAs(): string
    {
        return 'test-event';
    }
}

然后在 tinker 中执行:

event(new App\Events\TestEvent());

如果前端已订阅 test-channel,且控制台能看到 test-event 消息,说明链路通了。

  • Reverb 日志默认输出到 storage/logs/reverb.log,连接拒绝、鉴权失败等错误都在这里;权限问题(如 Redis 连接失败)会导致 reverb:start 启动瞬间退出,无日志 —— 此时加 --verbose 参数重试
  • 不要依赖 php artisan serve 来跑 Reverb;它必须作为独立进程运行,且与 Laravel 应用共享同一份 .env
  • 生产环境务必用 Supervisor 或 systemd 管理 php artisan reverb:start 进程,否则终端关闭就断了

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
laravel组件介绍
laravel组件介绍

laravel 提供了丰富的组件,包括身份验证、模板引擎、缓存、命令行工具、数据库交互、对象关系映射器、事件处理、文件操作、电子邮件发送、队列管理和数据验证。想了解更多laravel的相关内容,可以阅读本专题下面的文章。

338

2024.04.09

laravel中间件介绍
laravel中间件介绍

laravel 中间件分为五种类型:全局、路由、组、终止和自定。想了解更多laravel中间件的相关内容,可以阅读本专题下面的文章。

290

2024.04.09

laravel使用的设计模式有哪些
laravel使用的设计模式有哪些

laravel使用的设计模式有:1、单例模式;2、工厂方法模式;3、建造者模式;4、适配器模式;5、装饰器模式;6、策略模式;7、观察者模式。想了解更多laravel的相关内容,可以阅读本专题下面的文章。

686

2024.04.09

thinkphp和laravel哪个简单
thinkphp和laravel哪个简单

对于初学者来说,laravel 的入门门槛较低,更易上手,原因包括:1. 更简单的安装和配置;2. 丰富的文档和社区支持;3. 简洁易懂的语法和 api;4. 平缓的学习曲线。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

383

2024.04.10

laravel入门教程
laravel入门教程

本专题整合了laravel入门教程,想了解更多详细内容,请阅读专题下面的文章。

133

2025.08.05

laravel实战教程
laravel实战教程

本专题整合了laravel实战教程,阅读专题下面的文章了解更多详细内容。

82

2025.08.05

laravel面试题
laravel面试题

本专题整合了laravel面试题相关内容,阅读专题下面的文章了解更多详细内容。

72

2025.08.05

nginx 重启
nginx 重启

nginx重启对于网站的运维来说是非常重要的,根据不同的需求,可以选择简单重启、平滑重启或定时重启等方式。本专题为大家提供nginx重启的相关的文章、下载、课程内容,供大家免费下载体验。

245

2023.07.27

Golang 测试体系与代码质量保障:工程级可靠性建设
Golang 测试体系与代码质量保障:工程级可靠性建设

Go语言测试体系与代码质量保障聚焦于构建工程级可靠性系统。本专题深入解析Go的测试工具链(如go test)、单元测试、集成测试及端到端测试实践,结合代码覆盖率分析、静态代码扫描(如go vet)和动态分析工具,建立全链路质量监控机制。通过自动化测试框架、持续集成(CI)流水线配置及代码审查规范,实现测试用例管理、缺陷追踪与质量门禁控制,确保代码健壮性与可维护性,为高可靠性工程系统提供质量保障。

24

2026.02.28

热门下载

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

精品课程

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

共137课时 | 12.7万人学习

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

共6课时 | 11.3万人学习

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

共13课时 | 1.0万人学习

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

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