最近使用wsdlpull开源库curl模块调用webservice服务的压力测试的时候遇到的一个问题,其直接表象是客户端在发送http请求时失败,最终原因是客户端的TIME_WAIT状态的socket进程过多,导致端口被占满。
程序中执行代码段,res返回状态码CURLE_COULDNT_CONNECT:
CURLcode res = curl_easy_perform(m_ctx);
netstat下TIME_WAIT状态的tcp连接说明:
1.这是一种处于连接完全关闭状态前的状态;
2.通常要等上2分钟(windows server)的时间才能完全关闭;
3.这种状态下的tcp连接占用句柄与端口等资源,服务器也要为维护这些连接状态消耗资源;
4.解决这种TIME_WAIT的tcp连接只有让服务器能够快速回收和重用那些TIME_WAIT的资源:修改注册表(regedit)
[HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\services\Tcpip\Parameters]
添加dword(32-位)值TcpTimedWaitDelay=30(30秒也为微软建议值;默认为2分钟)
添加dword(32-位)值MaxUserPort=65534(可选值5000 - 65534);
5.具体tcpip连接参数配置还可参照这里:http://technet.microsoft.com/zh-tw/library/cc776295%28v=ws.10%29.aspx
Windows Registry Editor Version 5.00
[HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\services\Tcpip\Parameters]
"TcpTimedWaitDelay"=dword:0000001e
"MaxUserPort"=dword:0000fffe
将上述注册表内容保存为.reg文件,导入到注册表即可。
必须重新启动 Microsoft Windows 以使新设置生效