JVM之jmap java内存映射工具

jmap java内存映射工具

1、jmap

jdk安装后会自带一些小工具,jmap命令(Memory Map for Java)是其中之一。主要用于打印指定Java进程(或核

心文件、远程调试服务器)的共享对象内存映射或堆内存细节。

jmap命令可以获得运行中的jvm的堆的快照,从而可以离线分析堆,以检查内存泄漏,检查一些严重影响性能的

大对象的创建,检查系统中什么对象最多,各种对象所占内存的大小等等。可以使用jmap生成Heap Dump。

如果不想使用jmap命令,要想获取Java堆转储快照还有一些比较暴力的手段:譬如在前面用过的

-XX:+HeapDumpOnOutOfMemoryError参数,可以让虚拟机在OOM异常出现之后自动生成dump文件,通过

-XX:+HeapDumpOnCtrlBreak参数可以使用[ctrl]+[Break]键让虚拟机生成dump文件,又或者在Linux系统下通过

Kill -3 命令发送进程退出信息恐吓一下虚拟机,也能拿到dump文件。

jmap的作用并不仅仅是为了获取dump文件,他还可以查询finalize执行队列,java堆和永久代的详细信息,如空

间使用率、当前用的是哪种收集器等。

2、jmap命令

主要选项:

选项 作用
-dump 生成java堆转储快照,格式为:-dump:[live,]format=b,file=,其中live子参数说明是否只dump出存活对象
-finalizerinfo 显示在F-Queue中等待Finalizer线程执行finalize方法的对象,只在linux/solaris平台下有效
-heap 显示堆详细信息,如使用哪种回收期、参数配置、分带状况等,只在linux/solaris平台下有效
-histo 显示堆中对象统计信息,包括类、实例数量和合计容量
-permstat 以ClassLoader为统计口径显示永久代内存状况,只在linux/solaris平台下有效
-F 当虚拟机进程对-dump选项没有响应时,可以使用这个选项强制生成dump快照,只在linux/solaris平台下有效

2.1 jmap -dump

生成java堆转储快照:

格式:jmap -dump:[live,]format=b,file=文件路径 pid

JVM之jmap java内存映射工具_第1张图片

可以使用jdk提供的jvisualvm查看hprof文件

2.2 jmap -heap

显示堆详细信息:

格式:jmap -heap pid

JVM之jmap java内存映射工具_第2张图片

2.3 jmap -histo

显示堆中对象统计信息,包括类、实例数量和合计容量

命令:jmap -histo[:live] pid

JVM之jmap java内存映射工具_第3张图片

JVM之jmap java内存映射工具_第4张图片

你可能感兴趣的:(java,java)