使用liunx进行压力测试时出现很多异常,都是java.net.NoRouteToHostException: Cannot assign requested address.
错误原因
由于liunx 分配的客户端连接端口用尽,无法建立socket连接所致,虽然socket正常关闭,但是端口不是立即释放,而是处于 TIME_WAIT 状态,默认等待60s后释放。
查看liunx支持的客户端连接端口范围,也就是 28232 个端口。
1 | cat /proc/sys/net/ipv4/ip_local_port_range |
解决方法
- 调低端口释放后的等待时间,默认为60s,修改为15~30s。
echo 30 > /proc/sys/net/ipv4/tcp_fin_timeout
- 修改 tcp/ip 协议配置,通过配置
/proc/sys/net/ipv4/tcp_tw_reuse
,默认为0,修改为1,释放TIME_WAIT
端口给新连接使用。echo 1 > /proc/sys/net/ipv4/tcp_tw_reuse
- 修改 ctp/ip 协议配置,快速回收socket资源,默认为0.修改为1。
echo 1 > /proc/sys/net/ipv4/tcp_tw_recycle