jmap(Memory Map for java)
jmap命令用于生成堆转储快照(一般称为heapdump或dump文件)
如果不使用jmap命令,要想获取java堆转储快照,还有一些比较暴力的手段:譬如使用一个jvm参数 -XX:+HeapDumpOnOutOfMemoryError,可以让虚拟机在发生OOm异常的时候自动生成dump文件,通过-XX:HeapDumpOnCtrlBreak参数,则可以使用[Ctrl]+[Break]键让虚拟机生成dump文件,又或者在Linux系统下通过Kill -3 命令发送进程退出信号“吓唬”一下虚拟机,也能拿到dump文件。
参数的我都试过是没有问题的Linux命令我并没有尝试
jmap的作用不仅仅是为了获取dump文件,他还可以查询finalize执行队列,Java堆和永久代的详细信息,如空间使用率,当前用的那种收集器等。
和jinfo命令一样,jmap有不少功能在Windows平台下都是受限的,除了生成dump文件的 -dump选项和用于查看每个类的实例,空间占用统计的 -histo选项
在所有操作系统都提供之外,其余的选项只能在Linux/Solaris平台使用(这点是不是为了推广Linux么 0.0)
好了,下来就要学习命令了,以及执行
jmap [option] vmid
虽说命令的功能有限制,但是我们还是都列举出来吧
-dump 生成java堆转储快照,格式为:-dump:[live, ]format=b, file=,其中live自参数说明只有dump出存活的对象
-finalizerinfo 显示在F-Queue中等待Finalizer线程执行finalizer方法的对象
-heap 显示java堆详细信息,如使用那种回收器,参数配置,分代状况
-histo 显示堆中对象的统计信息,包括类,实例数量,合计容量
-permstat 以ClassLoader为统计口径显示永久代内存状态
-F 当虚拟机进程对-dump选项没有响应时,可使用这个选项强制生成dump快照
下面就是例子,图片
我们来一个dump文件的生成
jmap -dump:format-b,file=eclipse.bin 6832
可以看到文件已经创建,创建的目录就是pwd所在的当前目录
那么剩下的问题就是如何分析dump文件了!!!