0

0

ThinkPHP5.0集成Workerman WebSocket连接失败:如何排查服务器端及客户端配置问题?

碧海醫心

碧海醫心

发布时间:2025-03-21 08:14:24

|

1077人浏览过

|

来源于php中文网

原创

thinkphp5.0集成workerman websocket连接失败排查指南

本文针对ThinkPHP5.0框架结合Workerman构建WebSocket服务,前端JS无法连接的问题,提供详细的排查步骤。

ThinkPHP5.0集成Workerman WebSocket连接失败:如何排查服务器端及客户端配置问题?

问题描述:用户使用TP5.0.24、PHP 5.6.40和Workerman 3.5.31在Linux(宝塔面板)环境下搭建WebSocket服务,服务端运行正常,但浏览器端JS代码无法连接,尝试过127.0.0.1、0.0.0.0和服务器公网IP均失败,服务器2222端口已开放。

代码示例:

立即学习PHP免费学习笔记(深入)”;

服务端 (workercontroller.php):

<?php
namespace app\push\controller;

use think\worker\server;

class workercontroller extends server
{
    protected $socket = 'websocket://127.0.0.1:2222';

    // ... 其他方法 ...
}

前端JS代码:

ws = new WebSocket("ws://47.***.***.57:2222"); // 或 ws://127.0.0.1:2222
// ... 其他代码 ...

server.php:

歌者PPT
歌者PPT

歌者PPT,AI 写 PPT 永久免费

下载
#!/usr/bin/env php
<?php
define('APP_PATH', __DIR__ . '/application/');
define('BIND_MODULE', 'push/Worker');
require __DIR__ . '/thinkphp/start.php';

排查步骤:

  1. 防火墙: 即使端口2222已在宝塔面板中开放,也需仔细检查服务器防火墙是否允许外部访问该端口。

  2. $socket 配置: workercontroller.php 中的 $socket 属性 websocket://127.0.0.1:2222 只监听本地连接。若需外部访问,需修改为 websocket://0.0.0.0:2222 或服务器公网IP地址,修改后重启Workerman服务。

  3. 服务端代码错误: 检查 onMessageonConnectonCloseonErroronWorkerStart 方法的实现,潜在错误可能导致连接失败或消息处理异常。 务必检查错误处理机制。

  4. server.php 配置: 确认 server.php 中的 BIND_MODULE 是否正确指向Workerman控制器所在的模块。任何配置错误都可能导致Workerman无法正常启动或加载控制器。

  5. ThinkPHP5与Workerman集成: 确保ThinkPHP5框架和Workerman的集成配置正确,检查 composer.json 文件,确保Workerman依赖已正确安装和加载。

建议按照以上步骤逐一排查,并提供完整的代码和错误信息以便更有效地分析问题。 $socket 配置和防火墙设置通常是外部连接失败的主要原因。

热门AI工具

更多
DeepSeek
DeepSeek

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

豆包大模型
豆包大模型

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

WorkBuddy
WorkBuddy

腾讯云推出的AI原生桌面智能体工作台

腾讯元宝
腾讯元宝

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

文心一言
文心一言

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

讯飞写作
讯飞写作

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

即梦AI
即梦AI

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

ChatGPT
ChatGPT

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

相关专题

更多
composer是什么插件
composer是什么插件

Composer是一个PHP的依赖管理工具,它可以帮助开发者在PHP项目中管理和安装依赖的库文件。Composer通过一个中央化的存储库来管理所有的依赖库文件,这个存储库包含了各种可用的依赖库的信息和版本信息。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

162

2023.12.25

json数据格式
json数据格式

JSON是一种轻量级的数据交换格式。本专题为大家带来json数据格式相关文章,帮助大家解决问题。

457

2023.08.07

json是什么
json是什么

JSON是一种轻量级的数据交换格式,具有简洁、易读、跨平台和语言的特点,JSON数据是通过键值对的方式进行组织,其中键是字符串,值可以是字符串、数值、布尔值、数组、对象或者null,在Web开发、数据交换和配置文件等方面得到广泛应用。本专题为大家提供json相关的文章、下载、课程内容,供大家免费下载体验。

549

2023.08.23

jquery怎么操作json
jquery怎么操作json

操作的方法有:1、“$.parseJSON(jsonString)”2、“$.getJSON(url, data, success)”;3、“$.each(obj, callback)”;4、“$.ajax()”。更多jquery怎么操作json的详细内容,可以访问本专题下面的文章。

337

2023.10.13

go语言处理json数据方法
go语言处理json数据方法

本专题整合了go语言中处理json数据方法,阅读专题下面的文章了解更多详细内容。

82

2025.09.10

js正则表达式
js正则表达式

php中文网为大家提供各种js正则表达式语法大全以及各种js正则表达式使用的方法,还有更多js正则表达式的相关文章、相关下载、相关课程,供大家免费下载体验。

531

2023.06.20

js获取当前时间
js获取当前时间

JS全称JavaScript,是一种具有函数优先的轻量级,解释型或即时编译型的编程语言;它是一种属于网络的高级脚本语言,主要用于Web,常用来为网页添加各式各样的动态功能。js怎么获取当前时间呢?php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

576

2023.07.28

js 字符串转数组
js 字符串转数组

js字符串转数组的方法:1、使用“split()”方法;2、使用“Array.from()”方法;3、使用for循环遍历;4、使用“Array.split()”方法。本专题为大家提供js字符串转数组的相关的文章、下载、课程内容,供大家免费下载体验。

760

2023.08.03

TypeScript类型系统进阶与大型前端项目实践
TypeScript类型系统进阶与大型前端项目实践

本专题围绕 TypeScript 在大型前端项目中的应用展开,深入讲解类型系统设计与工程化开发方法。内容包括泛型与高级类型、类型推断机制、声明文件编写、模块化结构设计以及代码规范管理。通过真实项目案例分析,帮助开发者构建类型安全、结构清晰、易维护的前端工程体系,提高团队协作效率与代码质量。

26

2026.03.13

热门下载

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

精品课程

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

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