java 的ServeSocket类中,使用accept方法循环取出请求到的Socket对象,但是运行一段时间后,不再请求了,找不到原因,目前能够提供的信息整理如下,请高人指点原因或排查思路:
1.关键代码:
//接待
private boolean receiveStatus = false;
class ReceiveThread implements Runnable{
@Override
public void run() {
while(receiveStatus){
try{
Socket client = serverSocket.accept();
checkClient(client);
}catch(Exception e){
//Log.write("接待线程发生异常。");
}
}
}
}
private void checkClient(Socket s){
//Log.write("新的客户接入");
ThreadPool.getPool().submit(new CheckClient(s));
}
思路:首先开启一个接待线程,循环accept接收新的Socket对象,然后立即将该对象转到另一个线程(线程由线程池产生),进行进一步的交互处理。
2.问题的发现
以上代码开始运行时并没有什么异常,应用各项功能均正常。在服务器运行10天左右时,问题发生,客户端(Socket)无法与该应用建立连接,查看数据发现,客户端数据正常发出,但未收到来自服务器端的任何回应。
此时检查服务器应用进程依然存在,内存空闲量充足,于是使用 netstat -aptn 命令查看相关网络服务的连接状态发现问题。
tcp6 51 0 :::443 :::* LISTEN 8322/java
可以 51 指的是 Qecv-Q 指的是接收队列,也就是来自客户端的请求,可以看到队列已经积累了很多但是没有将数据取出。 端口监听正常。