netstat -ano | findstr "8611"查看到大量的TIME_WAIT状态的解决办法

最近使用wsdlpull开源库curl模块调用webservice服务的压力测试的时候遇到的一个问题,其直接表象是客户端在发送http请求时失败,最终原因是客户端的TIME_WAIT状态的socket进程过多,导致端口被占满。

netstat -ano | findstr

程序中执行代码段,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文件,导入到注册表即可。

netstat -ano | findstr

必须重新启动 Microsoft Windows 以使新设置生效

你可能感兴趣的:(安装部署)