php之Swoole连接服务器

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

使用 Swoole 连接服务器,核心是区分“你是客户端还是服务端”——Swoole 既支持作为客户端发起连接(如连 Redis、MySQL、HTTP 接口),也支持作为服务端监听连接(如 TCP/HTTP/WebSocket 服务器)。下面按常见场景说明关键点和写法。

作为客户端连接远程服务

Swoole 提供 Swoole\Coroutine\Http\ClientSwoole\Coroutine\RedisSwoole\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 手动测通断。

基本上就这些。连得上靠配置和网络通畅,连得稳靠协程管理与错误处理,连得快靠复用连接和合理超时。不复杂但容易忽略细节。