visualVM打不开 Exception in thread “main” java.lang.NoClassDefFoundError
1. 问题描述
使用版本
在高版本JDK(大于1.8或后期更新的1.8版本)中已经不会再自动集成 VisualVM
visualvm各版本下载地址
我的版本:
jdk | visualvm |
---|---|
11.0.12 | 1.4.2 及以上 |
操作流程
下载完后,将visualvm解压到jdk目录中,然后在cmd中输入
visualvm
回车,然后报出以下错误信息
意思是缺少模块:“jdk.internal.jvmstat”,“jdk.attach”,“jdk.internal.jvmstat”
2. 错误分析
在cmd中输入以下命令查看visualvm日志信息
visualvm.exe -J-Dnetbeans.logger.console=true -J-ea -J-verbose
可以看到visualVM是在该jre目录下执行的,而jre在jdk1.8版本之后是都不会提供的.而这个jre是之前通过cmd命令生成的
bin\jlink.exe --module-path jmods --add-modules java.desktop,jdk.internal.jvmstat,jdk.attach --output jre
但是,如果使用jlink创建自己的映像,它将剥离visualVm需要的模块,同时让visualVM混淆,去找jre目录.
3. 解决方法
- 使用常规的JDK,不要使用jlink创建jre
- 如果非得使用jlink创建jre,要么不要创建在jdk目录下,要么需要添加visualVM所缺失的模块jdk.internal.jvmstat/jdk.attach /jdk.internal.jvmstat