jmap
是 Java 虚拟机 (JVM) 中的一个命令行工具,用于生成堆转储。这个工具对于诊断内存问题、分析内存占用情况等非常有用。
jmap 官方文档
bash: jmap: command not found
命令找不到
# jmap -dump <pid>
jmap -dump 137886
安装一下java-devel
yum -y install java-devel
查看jmap
jmap
官网截图
参数
- <no option>
如果不使用任何选项,jmap命令将打印共享对象映射。对于目标JVM中加载的每个共享对象,将打印共享对象文件的起始地址、映射大小和完整路径。此行为类似于Oracle Solaris pmap实用程序。
- -dump:[live,] format=b, file=filename
将hprof二进制格式的Java堆转储为filename。live子选项是可选的,但如果指定,则只转储堆中的活动对象。要浏览堆转储,可以使用jhat(1)命令读取生成的文件。
- -finalizerinfo
打印有关等待完成的对象的信息。
- -heap
打印所使用的垃圾收集、头配置和逐代堆使用情况的堆摘要。此外,还会打印出插入字符串的数量和大小。
- -histo[:live]
打印堆的直方图。对于每个Java类,都会打印对象的数量、以字节为单位的内存大小和完全限定的类名。JVM内部类名以星号(*)前缀打印。如果指定了活动子选项,则只计算活动对象。
- -clstats
打印Java堆的类加载程序统计信息。对于每个类加载器,都会打印其名称、活动程度、地址、父类加载器以及已加载的类的数量和大小。
- -F
武力当pid没有响应时,将此选项与jmap-dump或jmap-histo选项一起使用。此模式不支持实时子选项。
- -h
打印帮助消息。
- -help
打印帮助消息。
- -Jflag
将标志传递给运行jmap命令的Java虚拟机。
查看堆积在finalizer队列中的对象
jmap -histo 137886
jmap -clstats 137886
运行GC.class_stats
命令时遇到了“requires -XX:+UnlockDiagnosticVMOptions”的错误,那么你需要确保在启动Java应用程序时加入了-XX:+UnlockDiagnosticVMOptions
选项。
jmap -dump:format=b,file=tn1.hprof 137886
file=tn1.hprof 是保存文件
format=b
表示使用二进制格式输出堆转储。
使用二进制格式的优点是,你可以将输出保存到一个文件中,并且稍后可以使用jhat
工具来分析这个文件。这对于大型堆转储特别有用,因为文本格式可能会非常大并且难以处理。
打印堆的内存映射
# jmap -histo:live <pid>
jmap -histo:live 137886