选择GatewayWorker因PHP不适合长连接,它基于Workerman提供WebSocket支持,包含Gateway、BusinessWorker和Register三部分,用于实现实时通信;通过Composer安装后,配置start.php初始化服务,编写onMessage处理登录、消息转发;前端用WebSocket API连接,发送与接收数据;运行php start.php启动服务,建议生产环境结合Nginx反向代理。
PHPWebSocket通信通常不是直接通过原生PHP实现,因为PHP本身是短生命周期的脚本语言,不适合处理长连接。要实现WebSocket实时通信,推荐使用GatewayWorker——一个基于Workerman开发的PHP socket服务框架,专为高并发、长连接场景设计。
为什么选择GatewayWorker
GatewayWorker封装了底层socket逻辑,提供简单API,支持TCP/UDP/WebSocket协议,并内置心跳检测、消息广播、客户端管理等功能。它由Gateway(网关进程)、BusinessWorker(业务逻辑)和Register(注册中心)三部分组成,适合构建聊天室、通知系统等实时应用。安装方式:
composer require workerman/gateway-worker登录后复制
搭建WebSocket服务端
创建一个启动文件如start.php,初始化Gateway与BusinessWorker:use GatewayWorker\Gateway;use GatewayWorker\BusinessWorker;use Workerman\Worker;// 初始化gateway$gateway = new Gateway("websocket://0.0.0.0:8282");$gateway->name = 'ChatGateway';$gateway->count = 1; // 进程数$gateway->lanIp = '127.0.0.1';$gateway->startPort = 2300;// 初始化bussiness worker$worker = new BusinessWorker();$worker->name = 'ChatBusinessWorker';$worker->count = 1;$worker->registerAddress = '127.0.0.1:1236';// 启动所有服务Worker::runAll();登录后复制
在BusinessWorker
中编写事件回调处理业务逻辑,例如用户登录、消息转发:
前端Javascript连接WebSocket
浏览器通过标准WebSocket API连接服务端:const ws = new WebSocket("ws://your-server-ip:8282");ws.onopen = () => { console.log("已连接"); // 发送登录信息 ws.send(JSON.stringify({type: 'login', uid: 1001}));};ws.onmessage = (e) => { const data = JSON.parse(e.data); console.log("收到消息:", data);};// 发送消息function sendMsg() { ws.send(JSON.stringify({ type: 'say', content: document.getElementById('msg').value }));}登录后复制
运行与部署
确保服务器开放对应端口(如8282),执行:php start.php start -d登录后复制
-d 表示守护进程模式运行。可通过stop
、restart
控制服务状态。
立即学习“PHP免费学习笔记(深入)”;

AI实时多语言翻译专家!强大的语音识别、AR翻译功能。


注意:生产环境建议配合Nginx反向代理WebSocket连接,提升安全性与性能。
基本上就这些,不复杂但容易忽略细节。
以上就是PHPWebSocket怎么通信_PHP结合GatewayWorker实现WebSocket实时通信的详细内容,更多请关注php中文网其它相关文章!