有哪些工具可用于查看内置 JVM 分析器的输出?例如,我正在启动我的 JVM:
-agentlib:hprof=cpu=times,thread=y,cutoff=0,format=a,file=someFile.hprof.txt
这会生成 hprof(“JAVA PROFILE 1.0.1”)格式的输出。
过去我曾成功使用HPjmeter以合理的方式查看这些输出文件。但是,无论出于何种原因,使用当前版本的 Sun JVM 生成的文件都无法在当前版本的 HPjmeter 中加载:
java.lang.NullPointerException
at com.hp.jmeter.f.jb.a(Unknown Source)
at com.hp.jmeter.f.a.a(Unknown Source)
at com.hp.c.a.j.z.run(Unknown Source)
Exception in thread "HPeprofDataFileReaderThread" java.lang.AssertionError: null pointer exception from loader
at com.hp.jmeter.f.a.a(Unknown Source)
at com.hp.c.a.j.z.run(Unknown Source)
(他们为什么要混淆免费产品的字节码?!)
由此产生两个问题:
- 有谁知道这个 HPjmeter 错误的原因?(编辑:是的——见下文)
- 还有哪些其他工具可以读取 hprof 文件?为什么没有来自 Sun 的(有)?
我知道Eclipse TPTP和其他工具可以动态监控 JVMTI 数据,但我需要一个可以在事后处理生成的 hprof 文件的解决方案,因为部署的机器只有一个 JRE(不是 JDK)安装。
编辑:一位非常有帮助的 HPjmeter 开发人员在 HP ITRC 论坛上回答了我的问题,指出heap=dump
需要-agentlib
暂时包含在选项中,直到 HPjmeter 中的错误得到修复。这些信息使 HPjmeter 再次可行,但我仍然会留下这个问题,看看是否有人知道任何其他工具。
编辑:从 HPjmeter 4.0.00 版(05/2009 可用)开始,此错误已得到修复。