问题现象:
前几天客户的java服务出问题了,反馈说业务都不能操作,页面也不能登了,像宕机一样。登上Linux服务器一看,服务还在啊,也没内存溢出。
于是打算使用jmap命令导出dump分析一下,发现有报错:
Unable to open socket file: target process not responding or HotSpot VM not loaded
The -F option can be used when the target process is not responding
用jstack命令也是一样提示!
网上资料是说可能是权限问题,登录用户和启动服务的用户不一致;或者是/tmp/hsperfdata_$USER目录下面没有pid文件。但是我排查了也不是这两个问题!
最后解决:java服务使用了jetty的线程池QueuedThreadPool,该版本线程数最大值是250,后面发现服务把线程数用完了,导致新线程一直无法创建。
可能也因为该原因无法使用jmap和jstack命令,重启服务后一切正常。