tcpserver并发连接测试。
测试客户端pylot,服务器nginx,模拟100路并发,每秒可处理接近700请求。未出现error。
测试客户端pylot,服务器xserver,模拟100路并发,每秒可处理请求600多。不过,在40秒后,会出现error。
查看error信息,显示:
[Errno 99] Cannot assign requested address
客户端,查看连接信息:
netstat -ant | grep TIME_WAIT | wc -l
发现,非常多的TIME_WAIT.
服务端,查看连接信息:
netstat -ant
一切正常。
各种分析,各种猜测。
struct linger linger;
linger.l_onoff = 1;
linger.l_linger = 0;
err = ::setsockopt(m_SockFd, SOL_SOCKET, SO_LINGER, (const void *) &linger, sizeof(struct linger));服务器端添加上面代码,客户端的TIME_WAIT数量减少到基本为0.
wow!原来服务器可以控制客户端TIME_WAIT的数量。
本文通过使用pylot作为测试客户端,分别对nginx和xserver进行并发连接测试。结果显示,在模拟100路并发的情况下,nginx每秒能处理接近700个请求且未出现错误;而xserver虽然也能处理600多个请求,但在40秒后开始出现错误。通过调整服务器端代码设置SO_LINGER选项,成功减少了客户端TIME_WAIT状态的数量。
1202

被折叠的 条评论
为什么被折叠?



