jhat 全称为 Java Virtual Machine Heap Analysis Tool,即虚拟机堆转储快照分析工具。jhat 用于分析 heapdump 文件,它会建立一个HTTP/HTML 服务器,让用户可以在浏览器上查看分析结果。
jhat 一般与 jmap 搭配使用,用于分析 jmap 生成的堆转储快照。jhat 是一个命令行工具,使用起来比较简便,但功能也相对简陋。如果条件允许的话,建议使用 JProfiler 或者 IBM HeapAnalyzer 等功能更强大的工具来分析 heapdump 文件。
语法
jhat [options] heap-dump-file
option 具体选项及作用如下:
- -J< flag >:因为 jhat 命令实际上会启动一个 JVM 来执行,通过 -J 可以在启动 JVM 时传入一些启动参数。例如,-J-Xmx512m 指定运行 jhat 的 JVM 使用的最大堆内存为 512 MB。 如果需要使用多个 JVM 启动参数,则传入多个 -Jxxxxxx。
- -stack false|true:关闭跟踪对象分配调用堆栈。如果分配位置信息在堆转储中不可用,则必须将此标志设置为 false。默认值为 true。
- -refs false|true:关闭对象引用跟踪。默认情况下,返回的指针是指向其他特定对象的对象,如反向链接或输入引用(referrers or incoming references),,会统计/计算堆中的所有对象。
- -port port-number:设置 jhat HTTP server 的端口号,默认值 7000。
- -exclude exclude-file:指定对象查询时需要排除的数据成员列表文件。 例如,如果文件列出了 java.lang.String.value,那么当从某个特定对象 Object o 计算可达的对象列表时,引用路径涉及 java.lang.String.value 的都会被排除。
- -baseline exclude-file:指定一个基准堆转储(baseline heap dump)。 在两个 heap dump 文件中有相同 object ID 的对象会被标记为不是新的(marked as not being new),其他对象被标记为新的(new)。在比较两个不同的堆转储时很有用。
- -debug int:设置 debug 级别,0 表示不输出调试信息。 值越大则表示输出更详细的 debug 信息。
- -version:启动后只显示版本信息就退出。
示例
使用 jhat 分析 jmap 生成的 hprof 文件:
localhost:7000 页面的最底部给出了可查看信息的列表:
分别为:
- All classes including platform:所有在堆中创建对象的类,包括 JDK 中定义的类。
- Show all members of the rootset:从根集能引用到的对象。
- Show instance counts for all classes (including platform):所有类(包括 JDK 中定义的类)的实例数量。
- Show instance counts for all classes (excluding platform):所有类(不包括 JDK 中定义的类)的实例数量。
- Show heap histogram:堆实例的分布表。
- Show finalizer summary:将要结束的对象的概括信息。
- Execute Object Query Language (OQL) query:执行对象查询语句,可以查看 OQL help,也可以参考博客 https://blog.csdn.net/a772304419/article/details/104022356 中的例子。
参考链接
- https://xixincan.github.io/2020/05/21/Java/JVM/jhat%E5%B7%A5%E5%85%B7%E8%AF%A6%E8%A7%A3/
- https://zhuanlan.zhihu.com/p/476375727
- https://blog.csdn.net/a772304419/article/details/104022356