PHP无法直接连接WebSocket服务器,报错10061是因用普通socket函数连WS端点、服务未启动、URL错误或缺少WebSocket握手头;应使用textalk/websocket等专用客户端库,或改用REST API、JS前端连接、Redis+Worker等更合适方案。

PHP 本身不支持直接连接 WebSocket 服务器(如 wss:// 或 ws://),所谓“PHP 连接 WebSocket 报错 10061”本质是误用了 PHP 的普通 socket 函数去连 WebSocket 握手端点,或混淆了客户端与服务端角色。
为什么 fsockopen 或 stream_socket_client 连 ws:// 地址会报 10061?
错误 10061 是 Windows 下的 WSAECONNREFUSED:目标机器主动拒绝连接。常见原因:
- 你试图用 PHP 客户端直连一个只监听 HTTP/HTTPS 的 Web 服务器(比如 Nginx/Apache 默认不处理
ws://升级请求) - WebSocket 服务根本没启动,或监听在非公开地址(如
127.0.0.1:8080),而 PHP 脚本运行在 Docker 容器或远程环境里 - URL 写成了
ws://example.com,但实际后端 WebSocket 服务跑在example.com:8080,且未配置反向代理透传Upgrade头 -
stream_socket_client默认不发送 WebSocket 握手所需的Upgrade: websocket、Sec-WebSocket-Key等头,服务端直接断连,部分实现会返回 10061 或静默关闭
PHP 真正能用的 WebSocket 客户端方案有哪些?
要让 PHP 主动作为 WebSocket 客户端(发消息、收消息),必须用支持完整握手和帧解析的库:
-
textalk/websocket(轻量,纯 PHP,无依赖):适合简单场景,不支持 wss 证书校验需手动关verify_peer => false -
ratchet/php-websocket是服务端库,不能当客户端用 —— 常见误区 -
devristo/phpws已废弃,不推荐 - 如果只是发一次消息就退出(如通知类),更稳妥的做法是:用
curl调用 WebSocket 服务提供的 REST API(很多 ws 服务同时暴露 HTTP 接口),而非硬连 ws
示例(textalk/websocket):
无线网络修复工具是一款联想出品的小工具,旨在诊断并修复计算机的无线网络问题。它全面检查硬件故障、驱动程序错误、无线开关设置、连接设置和路由器配置。 该工具支持 Windows XP、Win7 和 Win10 系统。请注意,在运行该工具之前,应拔出电脑的网线,以确保准确诊断和修复。 使用此工具,用户可以轻松找出并解决 WiFi 问题,无需手动排查故障。它提供了一键式解决方案,即使对于非技术用户也易于使用。
立即学习“PHP免费学习笔记(深入)”;
use Textalk\Websocket\Client;
$client = new Client("ws://localhost:8080");
$client->send('hello');
echo $client->receive();
10061 错误排查顺序:先确认服务端是否可达
别急着改 PHP 代码,先验证底层连通性:
- 在 PHP 所在机器上执行:
telnet localhost 8080(或nc -zv localhost 8080),看是否能建立 TCP 连接 - 如果 telnet 失败 → 检查服务是否运行(
ps aux | grep ws)、端口是否 bind 到0.0.0.0(而非仅127.0.0.1)、防火墙/SELinux 是否拦截 - 如果 telnet 成功,但 PHP 仍报 10061 → 大概率是 URL 写错(比如漏了端口)、或服务端程序崩溃后端口被系统快速复用但未真正监听
- 用
tcpdump -i lo port 8080抓包,确认 PHP 进程是否真的发出了 SYN 包
用 PHP 当 WebSocket 客户端?先想清楚是不是真需要
绝大多数 PHP 场景(Web 页面通知、实时日志推送)其实应该由浏览器 JS 直连 WebSocket,PHP 只负责生成页面或提供鉴权 token;让 PHP 自己维持长连接既难调试又易阻塞 FPM 进程。如果你的“连接 WebSocket”只是为了触发某件事(如下发指令),用 Redis Pub/Sub + 后台常驻 Worker(如 reactphp)解耦更健壮。10061 往往不是连接参数问题,而是整个架构选型偏离了 PHP 的运行模型。










