Swoole连接服务器需先明确角色:作为客户端可用协程类(如Http/Redis/MySQL Client)异步连接远程服务;作为服务端则通过Server或Http/Server监听并处理连接,关键在协程环境、配置参数与网络调试。

使用 Swoole 连接服务器,核心是区分“你是客户端还是服务端”——Swoole 既支持作为客户端发起连接(如连 Redis、MySQL、HTTP 接口),也支持作为服务端监听连接(如 TCP/HTTP/WebSocket 服务器)。下面按常见场景说明关键点和写法。
作为客户端连接远程服务
Swoole 提供 Swoole/Coroutine/Http/Client、Swoole/Coroutine/Redis、Swoole/Coroutine/MySQL 等协程客户端,适合在协程环境(如 Swoole HTTP Server 或 go() 中)高效发起异步连接。
- 连接 HTTP 服务示例:
go(function () {
$client = new Swoole/Coroutine/Http/Client('httpbin.org', 443, true);
$client->set(['timeout' => 10]);
if ($client->post('/post', ['name' => 'swoole'])) {
echo $client->getBody();
}
});
登录后复制
- 注意:域名需解析为 IP,HTTPS 要传
true并确保 OpenSSL 支持;超时、重试、Header 设置都通过set()配置。 - 连接自定义 TCP 服务可用
Swoole/Coroutine/Client,指定 IP 和端口后调用connect()和send()/recv()。
作为服务端监听并接受连接
启动一个 TCP 或 HTTP 服务器,本质是创建 Server 实例、设置回调、调用 start()。
- TCP 服务器示例:
$server = new Swoole/Server('0.0.0.0', 9501);
$server->on('connect', function ($server, $fd) {
echo "Client {$fd} connected/n";
});
$server->on('receive', function ($server, $fd, $from_id, $data) {
$server->send($fd, "Echo: {$data}");
});
$server->on('close', function ($server, $fd) {
echo "Client {$fd} closed/n";
});
$server->start();
登录后复制
- 绑定地址建议用
0.0.0.0(监听所有网卡),生产环境务必限制max_conn和启用open_tcp_nodelay。 - HTTP 服务器更简单:
new Swoole/Http/Server,配合on('request')处理 PSR-7 风格请求。
连接过程中的关键细节
- 协程客户端必须在协程内运行(
go()或run()中),否则会报错或阻塞。 - 服务端默认单进程,如需多核请设
$server->set(['worker_num' => 4]);注意task_worker_num用于耗时任务分离。 - 连接失败常见原因:防火墙拦截、端口未开放、SELinux 限制、PHP 进程无网络权限、DNS 解析失败(可先 ping 或用 IP 测试)。
- 调试建议:开启 Swoole 日志(
log_file)、用netstat -tuln | grep 9501查端口、用telnet ip port手动测通断。
基本上就这些。连得上靠配置和网络通畅,连得稳靠协程管理与错误处理,连得快靠复用连接和合理超时。不复杂但容易忽略细节。
立即学习“PHP免费学习笔记(深入)”;
以上就是php之Swoole连接服务器的详细内容,更多请关注php中文网其它相关文章!
相关标签:


