0

0

Swoole如何在一个端口上同时处理HTTP和WebSocket

尼克

尼克

发布时间:2025-10-12 16:42:02

|

560人浏览过

|

来源于php中文网

原创

Swoole可通过单端口同时处理HTTP和WebSocket请求。1. 使用Swoole\Http\Server可自动识别协议类型:普通HTTP请求触发request事件,WebSocket握手请求(含Upgrade: websocket头)则触发open事件,后续通过message和close事件处理双向通信。2. 示例代码展示在9501端口监听,浏览器访问/health返回HTTP响应,WebSocket客户端连接时自动升级协议并进入长连接通信。3. Swoole底层自动判断请求类型,若需自定义校验可在request中检查upgrade头。4. 注意事项包括正确使用http://与ws://协议、Nginx代理时配置WebSocket支持、避免阻塞request回调及可按路径限制WebSocket接入。该机制无需额外端口或转发,实现简洁高效。

swoole如何在一个端口上同时处理http和websocket

Swoole 可以在一个端口上同时处理 HTTP 和 WebSocket 请求,关键在于使用 混合协议监听 和正确的请求类型判断。Swoole 的 HttpServer 基于 Server 模块,支持在同一个端口根据客户端请求的协议类型自动区分是普通 HTTP 还是 WebSocket 握手请求。

1. 使用 Swoole\Http\Server 同时支持 HTTP 与 WebSocket

Swoole 的 HttpServer 内置了对 HTTP 和 WebSocket 的支持。当客户端发起 WebSocket 连接时,会先发送一个 HTTP 协议的握手请求(包含 Upgrade: websocket 头),Swoole 能自动识别并升级为 WebSocket 连接。

你只需要注册两个事件:

  • request:处理普通的 HTTP 请求
  • open / message / close:处理 WebSocket 连接和消息
只要 WebSocket 握手成功,后续通信就不再是 HTTP,而是基于帧的双向长连接。

2. 示例代码:单端口处理两种协议

以下是一个完整的例子:

Mistral AI
Mistral AI

Mistral AI被称为“欧洲版的OpenAI”,也是目前欧洲最强的 LLM 大模型平台

下载
$server = new Swoole\Http\Server("0.0.0.0", 9501);

// 处理普通 HTTP 请求
$server->on("request", function ($request, $response) {
    if ($request->server['request_uri'] === '/health') {
        $response->header("Content-Type", "text/plain");
        $response->end("OK\n");
    } else {
        $response->status(404);
        $response->end("Not Found\n");
    }
});

// WebSocket 握手成功时触发
$server->on('open', function ($server, $req) {
    echo "WebSocket client connected: {$req->fd}\n";
});

// 接收 WebSocket 消息
$server->on('message', function ($server, $frame) {
    echo "Received message: {$frame->data} from {$frame->fd}\n";
    $server->push($frame->fd, "You said: {$frame->data}");
});

// WebSocket 连接关闭
$server->on('close', function ($server, $fd) {
    echo "Client {$fd} disconnected\n";
});

$server->start();

在这个例子中,所有请求都走 9501 端口:

  • 浏览器访问 http://your-server:9501/health → 触发 request 事件,返回 HTTP 响应
  • WebSocket 客户端连接 ws://your-server:9501 → 先触发 request(握手阶段),然后进入 open 事件,之后使用 messagepush 进行双向通信

3. 如何区分 HTTP 与 WebSocket 请求?

Swoole 在底层自动判断:

  • 如果请求头包含 Upgrade: websocket,且是合法握手请求,Swoole 自动升级为 WebSocket 连接,并触发 open 事件
  • 否则,作为普通 HTTP 请求交给 request 回调处理

你也可以在 request 中手动判断是否为 WebSocket 握手:

$server->on("request", function ($request, $response) {
    if (isset($request->header['upgrade']) && strtolower($request->header['upgrade']) == 'websocket') {
        // 这是 WebSocket 握手,通常不在此处拦截,让 Swoole 自动处理即可
        // 正常情况下无需手动响应,Swoole 会自动完成握手
    } else {
        // 普通 HTTP 请求
        $response->end("Hello HTTP");
    }
});
一般不需要手动处理握手,Swoole 会自动完成,除非你需要自定义校验逻辑(如检查 Origin 或 Token)。

4. 注意事项

  • 确保客户端使用正确的协议:http:// 对应普通请求,ws:// 对应 WebSocket
  • 生产环境建议配合 Nginx 反向代理时,注意配置 WebSocket 支持(设置 UpgradeConnection 头)
  • 避免在 request 回调中长时间阻塞,影响 WebSocket 实时性
  • 可以结合路由判断,例如只允许特定路径进行 WebSocket 连接
基本上就这些。Swoole 的设计使得单端口同时服务 HTTP 和 WebSocket 非常自然,不需要额外端口或复杂转发。

相关专题

更多
nginx 重启
nginx 重启

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

229

2023.07.27

nginx 配置详解
nginx 配置详解

Nginx的配置是指设置和调整Nginx服务器的行为和功能的过程。通过配置文件,可以定义虚拟主机、HTTP请求处理、反向代理、缓存和负载均衡等功能。Nginx的配置语法简洁而强大,允许管理员根据自己的需要进行灵活的调整。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

498

2023.08.04

nginx配置详解
nginx配置详解

NGINX与其他服务类似,因为它具有以特定格式编写的基于文本的配置文件。本专题为大家提供nginx配置相关的文章,大家可以免费学习。

498

2023.08.04

tomcat和nginx有哪些区别
tomcat和nginx有哪些区别

tomcat和nginx的区别:1、应用领域;2、性能;3、功能;4、配置;5、安全性;6、扩展性;7、部署复杂性;8、社区支持;9、成本;10、日志管理。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

227

2024.02.23

nginx报404怎么解决
nginx报404怎么解决

当访问 nginx 网页服务器时遇到 404 错误,表明服务器无法找到请求资源,可以通过以下步骤解决:1. 检查文件是否存在且路径正确;2. 检查文件权限并更改为 644 或 755;3. 检查 nginx 配置,确保根目录设置正确、没有冲突配置等等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

333

2024.07.09

Nginx报404错误解决方法
Nginx报404错误解决方法

解决方法:只需要加上这段配置:try_files $uri $uri/ /index.html;即可。想了解更多Nginx的相关内容,可以阅读本专题下面的文章。

3508

2024.08.07

nginx部署php项目教程汇总
nginx部署php项目教程汇总

本专题整合了nginx部署php项目教程汇总,阅读专题下面的文章了解更多详细内容。

14

2026.01.13

nginx配置文件详细教程
nginx配置文件详细教程

本专题整合了nginx配置文件相关教程详细汇总,阅读专题下面的文章了解更多详细内容。

19

2026.01.13

高德地图升级方法汇总
高德地图升级方法汇总

本专题整合了高德地图升级相关教程,阅读专题下面的文章了解更多详细内容。

43

2026.01.16

热门下载

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

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
进程与SOCKET
进程与SOCKET

共6课时 | 0.3万人学习

nginx浅谈
nginx浅谈

共15课时 | 0.8万人学习

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

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