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 指的是接收队列,也就是来自客户端的请求,可以看到队列已经积累了很多但是没有将数据取出。 端口监听正常。
展开
 我来答
samismiling
2020-05-18 · 知道合伙人软件行家
samismiling
知道合伙人软件行家
采纳数:1340 获赞数:5604

向TA提问 私信TA
展开全部
我先列一下你的描述看看我理解的对不对:
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
另,从代码里如果不好判断,你就把日志打满,每个方法进入和离开的地方都打上日志
追问

辛苦您,因受到百度追问字数限制,我将回复以图片形式呈现,请您查看

推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式