1. linux高并发时出现
java.net.NoRouteToHostException: Cannot assign requested address
netstat -n | awk '/^tcp/ {++S[$NF]} END {for(a in S) print a, S[a]}'
- 查过资料后,发现是linux分配的客户端连接端口用完,无法建立socket连接导致,算然socket正常关闭,但是端口不是实时释放,而是处于TIME_WAIT状态,默认等待60S后释放
- 查看linux支持的客户端连接端口范围, 也就是28232个端口:
cat /proc/sys/net/ipv4/ip_local_port_range
32768 - 61000
2. 解决方案
- 调低端口释放后的等待时间, 默认为60s, 修改为15~30s
echo 3 > /proc/sys/net/ipv4/tcp_fin_timeout
- 修改tcp/ip协议配置, 通过配置/proc/sys/net/ipv4/tcp_tw_resue,默认为0, 修改为1,释放TIME_WAIT端口给新连接使用
echo 1 > /proc/sys/net/ipv4/tcp_tw_reuse
- 修改tcp/ip协议配置,快速回收socket资源, 默认为0, 修改为1.
echo 1 > /proc/sys/net/ipv4/tcp_tw_recycle
echo 3 > /proc/sys/net/ipv4/tcp_fin_timeout
echo 1 > /proc/sys/net/ipv4/tcp_tw_reuse
echo 1 > /proc/sys/net/ipv4/tcp_tw_recycle