17

我正在尝试在使用 open-jdk7 java 运行 glassfish 3.1.2 的机器上生成堆转储。

我正在使用以下命令:

jmap -dump:live,format=b,file=dump.t -F 24935

但我不断收到此错误:

Attaching to process ID 24935, please wait...
Debugger attached successfully.
Server compiler detected.
JVM version is 23.7-b01
Dumping heap to dump.t ...
Exception in thread "main" java.lang.reflect.InvocationTargetException
        at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
        at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:57)
        at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
        at java.lang.reflect.Method.invoke(Method.java:601)
        at sun.tools.jmap.JMap.runTool(JMap.java:197)
        at sun.tools.jmap.JMap.main(JMap.java:128)
Caused by: sun.jvm.hotspot.utilities.AssertionFailure: Expecting GenCollectedHeap, G1CollectedHeap, or ParallelScavengeHeap, but got sun.jvm.hotspot.gc_interface.CollectedHeap
        at sun.jvm.hotspot.utilities.Assert.that(Assert.java:32)
        at sun.jvm.hotspot.oops.ObjectHeap.collectLiveRegions(ObjectHeap.java:605)
        at sun.jvm.hotspot.oops.ObjectHeap.iterate(ObjectHeap.java:244)
        at sun.jvm.hotspot.utilities.AbstractHeapGraphWriter.write(AbstractHeapGraphWriter.java:51)
        at sun.jvm.hotspot.utilities.HeapHprofBinWriter.write(HeapHprofBinWriter.java:416)
        at sun.jvm.hotspot.tools.HeapDumper.run(HeapDumper.java:56)
        at sun.jvm.hotspot.tools.Tool.start(Tool.java:221)
        at sun.jvm.hotspot.tools.HeapDumper.main(HeapDumper.java:77)
        ... 6 more

这是我的完整 Java 版本:

[ufasoli]$ java -version
java version "1.7.0_19"
OpenJDK Runtime Environment (rhel-2.3.9.1.el6_4-x86_64)
OpenJDK 64-Bit Server VM (build 23.7-b01, mixed mode)

确切的 CentOS 版本是:

CentOS release 6.3 (Final)

有任何想法吗?

4

6 回答 6

14

发布这个,所以我不会自己忘记解决方案:P

这有效:

$ sudo /usr/lib/jvm/java-1.7.0-openjdk-1.7.0.51.x86_64/bin/jmap -dump:format=b,file=./testDump   8894
Dumping heap to /home/<snip>/testDump ...
Heap dump file created

这失败了:

$ sudo /usr/lib/jvm/java-1.7.0-openjdk-1.7.0.51.x86_64/bin/jmap -heap:format=b     8894
Attaching to process ID 8894, please wait...
Debugger attached successfully.
Server compiler detected.
JVM version is 24.45-b08
Dumping heap to heap.bin ...
Exception in thread "main" java.lang.reflect.InvocationTargetException
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:57)
at     sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
at java.lang.reflect.Method.invoke(Method.java:606)
at sun.tools.jmap.JMap.runTool(JMap.java:197)
at sun.tools.jmap.JMap.main(JMap.java:128)
Caused by: sun.jvm.hotspot.utilities.AssertionFailure: Expecting GenCollectedHeap, G1CollectedHeap, or ParallelScavengeHeap, but got sun.jvm.hotspot.gc_interface.CollectedHeap
at sun.jvm.hotspot.utilities.Assert.that(Assert.java:32)
at sun.jvm.hotspot.oops.ObjectHeap.collectLiveRegions(ObjectHeap.java:604)
at sun.jvm.hotspot.oops.ObjectHeap.iterate(ObjectHeap.java:244)
at sun.jvm.hotspot.utilities.AbstractHeapGraphWriter.write(AbstractHeapGraphWriter.java:51)
at sun.jvm.hotspot.utilities.HeapHprofBinWriter.write(HeapHprofBinWriter.java:416)
at sun.jvm.hotspot.tools.HeapDumper.run(HeapDumper.java:56)
at sun.jvm.hotspot.tools.Tool.start(Tool.java:221)
at sun.jvm.hotspot.tools.HeapDumper.main(HeapDumper.java:77)
... 6 more
于 2014-04-21T06:32:49.577 回答
7

这可能是相关的,但在某些 Java 版本上,最近的 RHEL / Centos(版本 >= 6)似乎有点奇怪,其中 jmap、jstack 和朋友需要以启动该过程的确切用户身份运行 - 而且它如果以 root 身份运行将不起作用

像这样的命令:

sudo -H -u <USERNAME WHO STARTED PROCESS> jmap -histo <PID>

应该照顾它,假设你有适当的 sudo 特权。

于 2016-12-30T15:01:44.177 回答
2

尝试不带 -F 选项运行

于 2013-09-24T14:22:55.020 回答
1

根据http://iamadevops.tumblr.com/post/109281462774/howto-fix-jmap-f-dump-format-b-on-archlinux,解决方案是“重新编译你的java,并没有去掉调试符号” .

于 2015-04-08T21:35:14.403 回答
0

如果您没有使用调试符号重新编译代码的选项并且您已配置 JMX,那么您可以尝试使用 VisualVM 生成 heapdump。

为此,启动 VisualVM 并通过 JMX 连接到主机。在监视器面板的左上角,您会看到一个“Head Dump”按钮。

转储文件的格式会有所不同,但您可以使用 jhat 或 VisualVM 打开它。

于 2015-06-09T11:02:18.293 回答
0

jmap并且jstack确实需要调试符号。幸运的是,您可能不需要重新编译您的 java.lang.

对于 Ubuntu:

# apt-get install openjdk-7-dbg

如果有人有 CentOS 的命令,请用它编辑这个答案。

https://bugzilla.redhat.com/show_bug.cgi?id=1010786#c15

之后,这对我有用。

# jmap -dump:live,file=dump -F 11316
于 2020-04-01T13:36:23.417 回答