使用jmap命令

时间:2018-01-25 08:28:04

标签: java jvm jvm-hotspot

我的jdk版本是1.8.0_111,我正在读一本关于JVM的书。当我尝试命令jmap -F 6469时,会抛出异常,如下所示:

Attaching to process ID 6469, please wait...
Error attaching to process: sun.jvm.hotspot.runtime.VMVersionMismatchException: Supported versions are 25.111-b14. Target VM is 25.152-b11
sun.jvm.hotspot.debugger.DebuggerException: sun.jvm.hotspot.runtime.VMVersionMismatchException: Supported versions are 25.111-b14. Target VM is 25.152-b11
    at sun.jvm.hotspot.HotSpotAgent.setupVM(HotSpotAgent.java:435)
    at sun.jvm.hotspot.HotSpotAgent.go(HotSpotAgent.java:305)
    at sun.jvm.hotspot.HotSpotAgent.attach(HotSpotAgent.java:140)
    at sun.jvm.hotspot.tools.Tool.start(Tool.java:185)
    at sun.jvm.hotspot.tools.Tool.execute(Tool.java:118)
    at sun.jvm.hotspot.tools.PMap.main(PMap.java:72)
    at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
    at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)
    at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
    at java.lang.reflect.Method.invoke(Method.java:498)
    at sun.tools.jmap.JMap.runTool(JMap.java:201)
    at sun.tools.jmap.JMap.main(JMap.java:130)
Caused by: sun.jvm.hotspot.runtime.VMVersionMismatchException: Supported versions are 25.111-b14. Target VM is 25.152-b11
    at sun.jvm.hotspot.runtime.VM.checkVMVersion(VM.java:227)
    at sun.jvm.hotspot.runtime.VM.<init>(VM.java:294)
    at sun.jvm.hotspot.runtime.VM.initialize(VM.java:370)
    at sun.jvm.hotspot.HotSpotAgent.setupVM(HotSpotAgent.java:431)
    ... 11 more

我的jvm版本似乎有问题,但我找不到原因。我是JVM的新手,如果有人能告诉我为什么以及如何处理它,我将不胜感激。

3 个答案:

答案 0 :(得分:3)

目标进程(6469)在不同版本的JRE(1.8.0_152)下运行。

在强制模式(-F)下运行jmapjstack时,该工具的JDK版本必须与目标进程的JDK完全相同。

有关详细信息,请参阅this answer

答案 1 :(得分:0)

更改Java路径后,我在ubuntu上解决了此问题。

编辑Java路径

sudo gedit /etc/profile

更改Java路径

export JAVA_HOME=/usr/lib/jvm/java-8-openjdk-amd64 (设置您正在使用的Java版本的Java路径)

重新启动系统。

答案 2 :(得分:0)

在Windows上可以使用psexec,因此我们不必使用-F选项。因此,您不必为jhat和Java进程使用完全相同的jdk版本。

当具有完全相同版本的jdk不可用时,这很有用。例如,在一个较大的组织中,有时人们只会更新jvm,而不会在生产系统上安装相同的jdk。

psexecPsTools捆绑包的一部分。您可以找到它们here。命令如下所示:

F:\Programs\PSTools\PsExec.exe -s jmap.exe <pid>

即使使用psexec,也可能需要足够的权限。