慎用TCP的选项SO_LINGER
2015-07-16 16:40
435 查看
最近有一次性能测试,通讯程序出现错误,表现为服务器处理速度明显降低,检查发现服务器的很多句柄出于TIME_WAIT状态,Justin这个流氓的自己承认测试用例写的有问题,在recv函数返回0后,没有close句柄。
我很郁闷google了一下如何处理这类错误,发现了SO_LINGER这个选项,发现这个选项可以避免端口的状态进入TIME_WAIT状态,大胆的进行了一下测试。发现在性能测试中,服务器的表现好了不少,暗爽。
//使用SO_LINGER,close后不进入TIME_WAIT状态
struct linger linger;
linger.l_onoff = 1;
linger.l_linger = 0;
setsockopt(serverSocket,
SOL_SOCKET, SO_LINGER,
(const char *) &linger,
sizeof(linger));
周3发版本,突然发现很多同事的都报告出现了一些错误,从客户端的日志反馈看,客户端在最后阶段往往没有收到几个我们的服务器的返回命令,于是立即想到了可能是这个选项导致了麻烦。注释这个选项后,果然大家的程序都正常了。
回头仔细读了一下《UNIX网络编程》卷1,才慢慢回想起来,TIME_WAIT的作用是保证在主动关闭端口后,保证数据让对端收到,Richard.Steven的原话是”TIME_WAIT是我们的朋友。”
由于我们客户端要和多个游戏服务器通讯,而且之间还有一些时序关系,所以我们不能使用这种让用户丢弃一部分数据的方式。对于TCP的细节感觉还是不熟悉,呵呵。
不能丢弃TIME_WAIT状态,但是让他缩短一些也是可以的。我们可以在l_linger参数上动点手脚,当l_onoff非0是。l_linge也非0的时候,套接口在TIME_WAIT上将拖延一段时间,l_linger秒,而不再是2MSL的超时[注]。我也打算继续试验一下。
【注】,根据《UNIX网络编程》卷1,需要注意的是,l_linger非0的解释在不同的平台可能不一样,BSD平台的实现是0.01s。
本文来自CSDN博客,转载请标明出处:http://blog.csdn.net/fullsail/archive/2009/08/08/4424324.aspx
我很郁闷google了一下如何处理这类错误,发现了SO_LINGER这个选项,发现这个选项可以避免端口的状态进入TIME_WAIT状态,大胆的进行了一下测试。发现在性能测试中,服务器的表现好了不少,暗爽。
//使用SO_LINGER,close后不进入TIME_WAIT状态
struct linger linger;
linger.l_onoff = 1;
linger.l_linger = 0;
setsockopt(serverSocket,
SOL_SOCKET, SO_LINGER,
(const char *) &linger,
sizeof(linger));
周3发版本,突然发现很多同事的都报告出现了一些错误,从客户端的日志反馈看,客户端在最后阶段往往没有收到几个我们的服务器的返回命令,于是立即想到了可能是这个选项导致了麻烦。注释这个选项后,果然大家的程序都正常了。
回头仔细读了一下《UNIX网络编程》卷1,才慢慢回想起来,TIME_WAIT的作用是保证在主动关闭端口后,保证数据让对端收到,Richard.Steven的原话是”TIME_WAIT是我们的朋友。”
由于我们客户端要和多个游戏服务器通讯,而且之间还有一些时序关系,所以我们不能使用这种让用户丢弃一部分数据的方式。对于TCP的细节感觉还是不熟悉,呵呵。
不能丢弃TIME_WAIT状态,但是让他缩短一些也是可以的。我们可以在l_linger参数上动点手脚,当l_onoff非0是。l_linge也非0的时候,套接口在TIME_WAIT上将拖延一段时间,l_linger秒,而不再是2MSL的超时[注]。我也打算继续试验一下。
【注】,根据《UNIX网络编程》卷1,需要注意的是,l_linger非0的解释在不同的平台可能不一样,BSD平台的实现是0.01s。
本文来自CSDN博客,转载请标明出处:http://blog.csdn.net/fullsail/archive/2009/08/08/4424324.aspx
相关文章推荐
- [转]redis服务器与客户端保活参数(tcp-keepalive)设置
- Android的网络与通信(转)
- Winform 客户端向服务端发送http请求
- Android框架之网络开发框架Volley
- 移动端网络数据抓包工具对比分析
- 中小型网络组建
- 服务器返回的各种HTTP状态码介绍
- Unity3D SpuerSocket 网络聊天室实现 <一>
- swift 使用 AFHTTPRequestOperationManager
- 计算机网络—传输层协议之UDP
- HttpURLConnection连接代码基本详…
- http与https的区别&nbsp;
- 各浏览器HTTP&nbsp;Get请求U…
- 黑马程序员-java网络编程
- 常用的网络命令
- 网络与多线程的设计例子
- 计算机网络—传输层协议之TCP
- HTTP协议的C/S模式的信息交换过程
- HTTP请求报文和HTTP响应报文
- 浏览器 HTTP 协议缓存机制详解及Http协议预处理工具类