Swoole的open_eof_check通过指定EOF标记解决TCP粘包问题,需配合package_eof设置结束符,仅当接收数据包含该标记才触发onReceive回调,适用于文本协议场景。

Swoole的open_eof_check配置项用于开启按协议分包的EOF检测机制,主要解决TCP粘包问题。当启用后,Swoole会持续接收数据,直到接收到预设的“结束符”(EOF标记)才认为一个完整数据包接收完毕。
作用与原理
在TCP通信中,多个发送的数据包可能被合并成一次接收(粘包),导致无法准确判断消息边界。open_eof_check通过指定一个特定字符串作为消息结尾(如"\r\n"、"\n"、"###"等),让Server自动识别并切分数据包。
只有当缓冲区中的数据包含该EOF标记时,连接才会触发onReceive回调;否则会继续等待后续数据,直到超时或凑齐完整包。
使用方法
- 需配合package_eof配置项一起使用,指定具体的结束符内容
- 常用于文本协议场景,比如自定义行协议、Redis协议前端通信等
- 仅对SWOOLE_SOCK_TCP、SWOOLE_SOCK_TCP6等流式套接字有效
示例设置:
$server = new Swoole\Server("127.0.0.1", 9501);
$server->set([
'open_eof_check' => true,
'package_eof' => "\r\n"
]);
注意事项
如果发送方未在每条消息末尾添加对应的EOF标记,会导致连接一直等待,最终可能触发red">buffer溢出或超时断开。因此必须确保客户端和服务端对EOF标记达成一致。
相比open_length_check(基于长度字段的分包),open_eof_check更适合简单文本协议,但不适合二进制协议或无法插入特殊字符的场景。
基本上就这些,关键在于正确设置package_eof并与业务协议匹配。










