天天看点

jvisualvm监控本地进程查看不到线程信息,且CPU报:Not supported for this JVM背景现象解决方法

背景

我本来是想查看一个本地java进程的线程堆栈信息,因为是在我本机中,所以想着用jvisualvm工具来看方便,省得敲命令,然而问题来了,不仅没有线程信息,而且jstack也不管用了

现象

下图是我机器上有问题的进程使用jvisualvm查看的结果:

jvisualvm监控本地进程查看不到线程信息,且CPU报:Not supported for this JVM背景现象解决方法
jvisualvm监控本地进程查看不到线程信息,且CPU报:Not supported for this JVM背景现象解决方法

在导航栏的Montior右边没有Threads信息,并且CPU监控这个区域,报的是Not supported for this JVM.

然后,我点击我旁边的IDEA的进程,查看,很正常,截图如下:

jvisualvm监控本地进程查看不到线程信息,且CPU报:Not supported for this JVM背景现象解决方法

问题来了,这两个都是本地进程,怎么会出现这种情况,我本意只是想看一下线程堆栈信息,既然jvisualvm不管用,那我用命令试下,结果这个异常进程还是有问题:

jvisualvm监控本地进程查看不到线程信息,且CPU报:Not supported for this JVM背景现象解决方法

这就很尴尬了,同样是本地进程,怎么会如此不同结果。我用的JDK版本是1.7的,本机上也就这一个,另外系统上也没什么权限禁止的。

在网上查了不少资料,但是没有一个可以解决我的问题的。

忽然,我想到了一种可能性,是不是和我启动的java进程的目录有关系。

解决方法

这个异常进程是我用IDEA启动的,所以不用考虑是配置方面的问题,那就应该是源码所在的目录位置的问题。

先解释下我的操作系统的目录情况:

我用的是ubuntu系统,电脑本来是有一个固态盘(装windows的时候是系统盘,后来被我分隔成俩盘,一个放系统,一个放应用),还有一个1个T的机械盘。

后来因某些原因,不能再用windows了,所有考虑装个ubuntu来作为日常工作使用了,但是又不舍得把个windows系统和已经装好的应用删除了(万一哪天又用上了呢),所以只能装双系统。

然后,我就在这个1个T的机械盘上开了100G的空间来装ubuntu,毕竟100G不大,平常使用是要放好多东西的,所以其它的空间也不能浪费了,于是我就把原来是windows下的分区全部挂载到这个ubuntu系统的目录下,平常工作中的文档,代码等乱七八糟的都放到其挂载的分区中,坚决不放到这100G这个分区下。

于是,我就想是不是因为这个异常进程的启动目录是在其它的分区下,所以有问题,而IDEA就是在我这个ubuntu系统所在的分区下所以没问题,于是把代码复制过来,试了下,果然没问题了。

那么,现在问题来了,代码在挂载的分区目录下,为什么导致jstack命令不可用了,我还没弄明白,不知道是文件系统类型的问题,还是啥子原因么。若有知道的大佬,希望能告知下,谢谢。