5

我正在尝试分析从遇到内存问题的 java 进程中提取的堆转储。转储是使用 jmap 进行的。我在转储文件上使用 jhat - 我得到

java.io.IOException: Unrecognized magic number: 169897589 at com.sun.tools.hat.internal.parser.Reader.readFile(Reader.java:94) at com.sun.tools.hat.Main.main(Main.java:159)

jdk 1.6 和 1.7 都给出相同的错误。我在我的 Windows 机器上本地运行 jhat(在复制转储文件之后)并且转储文件是在 Linux 服务器上获取的。

任何想法我做错了什么?

4

2 回答 2

4

如果您查看com.sun.tools.hat.internal.parser.Reader的源代码,您会发现它正在寻找幻数0x4a415641

此值用于帮助识别有效的堆转储文件。jmap应该将此值附加为它创建的任何堆转储文件的前四个字节。

我建议在十六进制编辑器中打开您的堆转储并检查前四个字节是否为0x4a415641. 在您的 Linux 和 Windows 机器上检查该文件。传输文件时,文件可能已损坏。

于 2013-03-19T18:44:18.933 回答
1

可能,您生成 jvm 转储文件的方法错误。使用 jmap -histo {pid} > dump.log 时发生错误。

尝试

   jmap -dump:live;file=文件名 pid

祝你好运。

于 2016-03-20T15:04:27.750 回答