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的数量。