Java 工具集教程

jhat.exe 堆储存查看器

jhat.exe 是 JDK 提供的一个命令行工具,用于分析 Java 堆转储(Heap Dump)文件。该工具可以将堆转储文件加载到内存中,并在网页浏览器中提供一个交互式的界面,用于浏览和分析堆中的对象。

命令语法

jhat [-stack <bool>] [-refs <bool>] [-port <port>] [-baseline <file>] [-debug <int>] [-version] [-h|-help] <file>

命令选项

jhat 命令支持如下选项:

  • -J<flag>  直接将 <flag> 传递给运行时系统。例如,-J-mx512m 表示最大堆大小为 512MB

  • -stack false  关闭跟踪对象分配调用堆栈。

  • -refs false  关闭对对象引用的跟踪

  • -port <port>  设置 HTTP 服务器的端口。 默认为 7000

  • -exclude <file>  指定一个文件,列出应从 reachableFrom 查询中排除的数据成员。

  • -baseline <file>  指定基线对象转储。 两个堆转储中具有相同 ID 和相同类的对象将被标记为非 "新 "对象。

  • -debug <int>  设置调试级别。0:无调试输出。1:调试 hprof 文件解析。2:调试 hprof 文件解析,无服务器。

  • -version  报告版本号

  • -h|-help  打印此帮助并退出

  • <file>  要读取的文件

注意:所有布尔选项默认为 true。对于包含多个堆转储的转储文件,可以通过在文件名后添加 "#<编号>" 来指定文件中的哪个转储,例如 "foo.hprof#3"。

命令示例

(1)使用 jmap 命令生成堆转储快照 dump 文件,如下:

D:\share_dir\ShareDoc> jmap -dump:format=b,file=heapdump.hprof 21108
Dumping heap to D:\share_dir\ShareDoc\heapdump.hprof ...
Heap dump file created

(2)使用 jhot 命令分析 dump 文件,并且运行在端口 7000 上,如下:

D:\share_dir\ShareDoc> jhat -port 7000 heapdump.hprof
Reading from heapdump.hprof...
Dump file created Mon Jul 08 21:49:22 CST 2024
Snapshot read, resolving...
Resolving 1496378 objects...
Chasing references, expect 299 dots...........................................................................................................................................................................................................................................................................................................
Eliminating duplicate references...........................................................................................................................................................................................................................................................................................................
Snapshot resolved.
Started HTTP server on port 7000
Server is ready.

运行上述命令后,jhat 会启动一个 HTTP 服务器。然后,你可以打开浏览器,访问 http://localhost:7000/  来查看和分析堆转储文件。如下图:

image.png

注意:

(1)jhat 对大型堆转储文件的处理可能会占用较大的内存。确保你的系统有足够的内存来运行 jhat 和分析堆转储文件。

(2)jhat 的输出结果可能比较详细,需要具备一定的内存分析经验来解读结果。

说说我的看法
全部评论(
没有评论
关于
本网站专注于 Java、数据库(MySQL、Oracle)、Linux、软件架构及大数据等多领域技术知识分享。涵盖丰富的原创与精选技术文章,助力技术传播与交流。无论是技术新手渴望入门,还是资深开发者寻求进阶,这里都能为您提供深度见解与实用经验,让复杂编码变得轻松易懂,携手共赴技术提升新高度。如有侵权,请来信告知:hxstrive@outlook.com
公众号