CLOSE_WAIT导致无法连接服务端
COMMAND PID USER FD TYPE DEVICE SIZE/OFF NODE NAME
问题描述
1. 项目部署到linux 服务器之后,运行一段时间(大概几个钟),会开始出现一些未释放的TCP连接(状态CLOSE_WAIT)
查看:" ps -ef|grep jar " 查看对应服务端进程号,通过 " lsof -p 进程号" 看到这个进程的TCP连接详情,发现很多客户端连接处于CLOSE_WAIT的情况
当出现这种情况的时候,会发现
客户端打开连接,开启端口之后,尝试去连,结果没连上(结果服务器多了条该链接的CLOSE_WAIT的TCP),
然后再点,再连还是没连上。
服务端压根没有收到连接的响应,没有处理。
然后再点,再连还是没连上。
服务端压根没有收到连接的响应,没有处理。
COMMAND PID USER FD TYPE DEVICE SIZE/OFF NODE NAME
java 19219 root 248u IPv4 95933465 0t0 TCP ********(服务器IP):4698->*******(客户端的IP):39303 (CLOSE_WAIT)
用过的解决方法
1. 调整MINA框架,检查各种关闭socket情况,设置超时时关闭SOCKET,异常时关闭socket,未解决。
2. 调整客户端,设置socket
服务端
// 设置连接超时时间
acceptor.getSessionConfig().setIdleTime(IdleStatus. BOTH_IDLE,
600);
// 允许重用本地地址和端口
acceptor.getSessionConfig().setReuseAddress(true);
// 连接返回,数据丢失
acceptor.getSessionConfig().setSoLinger(0);
客户端
socket.setSoLinger(true, 0); //当执行Socket的close()方法时,
是否立即关闭底层的Socket. --一般不能设置为0
socket.setReuseAddress(true);//允许重用Socket
所绑定的本地地址.
设置完之后,有所改善,但调整的客户端还是会出现连接不上,登录不了的问题
3. 调整MINA
acceptor.getSessionConfig().setKeepAlive(true);
//启用socket连接的KEEPALIVE
然后改系统参数
echo 120 > /proc/sys/net/ipv4/tcp_keepalive_time
echo 2 > /proc/sys/net/ipv4/tcp_keepalive_intvl
echo 1 > /proc/sys/net/ipv4/tcp_keepalive_probes
echo 2 > /proc/sys/net/ipv4/tcp_keepalive_intvl
echo 1 > /proc/sys/net/ipv4/tcp_keepalive_probes
改完后,服务端重启,运行了几个钟后发现出现CLOSE_WAIT,配置也生效了,CLOSE_WAIT会消失,但是还是一样会无法连接,登录不上。
4. linux系统 环境不同
待测试确认
项目在Linux服务器上运行时遇到CLOSE_WAIT状态的TCP连接,导致服务端无法正常接收客户端连接。通过调整MINA框架设置、客户端socket配置、启用TCP KEEPALIVE以及修改Linux系统参数,尝试解决此问题,但仍有登录失败和连接不上的现象。
801

被折叠的 条评论
为什么被折叠?



