java.net.NoRouteToHostException:Cannot assign requ

以下内容摘自:http://blog.sina.com.cn/s/blog_658c8cea0101l2sw.html  

今天压力测试时, 刚开始出现了很多异常, 都是 java.net.NoRouteToHostException:Cannot assign requested address.

经网上查资料, 是由于linux分配的客户端连接端口用尽,无法建立socket连接所致,虽然socket正常关闭,但是端口不是立即释放, 而是处于TIME_WAIT状态,默认等待60s后才释放。

  查看linux支持的客户端连接端口范围,也就是28232个端口:

    cat /proc/sys/net/ipv4/ip_local_port_range

    32768 - 61000

  解决方法:

  1. 调低端口释放后的等待时间, 默认为60s,修改为15~30s

    echo 30 >/proc/sys/net/ipv4/tcp_fin_timeout

  2. 修改tcp/ip协议配置,通过配置/proc/sys/net/ipv4/tcp_tw_resue, 默认为0, 修改为1,释放TIME_WAIT端口给新连接使用。

    echo 1 >/proc/sys/net/ipv4/tcp_tw_reuse

  3.修改tcp/ip协议配置,快速回收socket资源,  默认为0, 修改为1.

    echo 1 >/proc/sys/net/ipv4/tcp_tw_recycle

 

  通过上面3项调整,压力测试运行正常。

原文地址:https://www.cnblogs.com/winstonet/p/6916188.html