关于java:解决jstack的报错Unable-to-open-socket-file

原文网址:​​解决jstack的报错:Unable to open socket file_IT利刃出鞘的博客-CSDN博客​​

简介

阐明

本文介绍解决jstack的报错的办法,报错信息为:Unable to open socket file。

分享Java技术星球:​​自学精灵 – IT技术星球​​

具体报错信息:

过程号: 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、jmap等工具排查CPU占用高、内存占用低等问题。但在应用这些命令时有时会报错,如下所示:

起因及解决方案

1.用户权限不正确

起因

如果执行java程序的用户与执行jstack命令的用户不统一,会导致报错。

解决方案

切换到执行java程序的那个用户再执行jstack命令。

办法

第一步:查找java过程对应的用户(命令为:ps -aux | grep “过程号”)

例:

第二步:应用su命令切换到对应用户

su root

2./tmp门路没有过程信息

起因

java过程启动的时候,默认会在/tmp/hsperfdata_$USER上面创立一个以PID命名的文件,外面蕴含了一些信息,会被jstack、jmap命令应用到。当文件不存在时就会报上述谬误。

导致/tmp下没有相干文件的起因有:

  1. 应用了docker来启动
  2. 应用了systemd来启动(systemd用于监控过程状态)

解决方案

  • 如果是应用了docker来启动

<!—->

  • 解决办法:须要进入到容器中去执行jstack命令。

<!—->

  • 如果是应用了systemd来启动

<!—->

  • 解决办法:批改一项配置:PrivateTmp=true改为false

评论

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

这个站点使用 Akismet 来减少垃圾评论。了解你的评论数据如何被处理