Java ServerSocket accept运行一段时间不再接受新的连接了,这是为什么?
java的ServeSocket类中,使用accept方法循环取出请求到的Socket对象,但是运行一段时间后,不再请求了,找不到原因,目前能够提供的信息整理如下,请高人...
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 指的是接收队列,也就是来自客户端的请求,可以看到队列已经积累了很多但是没有将数据取出。 端口监听正常。 展开
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 指的是接收队列,也就是来自客户端的请求,可以看到队列已经积累了很多但是没有将数据取出。 端口监听正常。 展开
展开全部
我先列一下你的描述看看我理解的对不对:
1、你使用netstat命令发现系统仍然在接收客户端发送的请求;
2、你的程序没有处理这些请求;
从这两条看,明显是程序已经停了,但是你的代码里是:
1、while循环,只要你没有修改过receiveStatus,是不会自然结束的
2、你在while里立刻就try了,所以如果产生了Exception,是不可能结束的
结论:有3个可能:
1、从你代码看checkClient方法不是异步的,所以如果它停在某处,则整个程序都停了
2、调用Recevie类的方法本身出现了异常(就是new Receive().start()所在的方法本身异常了)
3、Recevie.run()里抛出的不是Exception,而是Error,你的try没有生效,程序崩了,这个可能是你的ChcekClient类有可能跑Error
另,从代码里如果不好判断,你就把日志打满,每个方法进入和离开的地方都打上日志
1、你使用netstat命令发现系统仍然在接收客户端发送的请求;
2、你的程序没有处理这些请求;
从这两条看,明显是程序已经停了,但是你的代码里是:
1、while循环,只要你没有修改过receiveStatus,是不会自然结束的
2、你在while里立刻就try了,所以如果产生了Exception,是不可能结束的
结论:有3个可能:
1、从你代码看checkClient方法不是异步的,所以如果它停在某处,则整个程序都停了
2、调用Recevie类的方法本身出现了异常(就是new Receive().start()所在的方法本身异常了)
3、Recevie.run()里抛出的不是Exception,而是Error,你的try没有生效,程序崩了,这个可能是你的ChcekClient类有可能跑Error
另,从代码里如果不好判断,你就把日志打满,每个方法进入和离开的地方都打上日志
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询