Java内存分析⼯具jmap
1.简述                                                   
  jmap是⼀个多功能的命令,它可以⽣成java程序的dump⽂件,也可以查看堆内对象⽰例的统计信息、查看ClassLoader的信息以及finalizer队列。
2.jmap的⽤法                                               
(1)jmap参数说明                                             
  参数说明:
option:选项参数。
pid:需要打印配置信息的进程ID。
executable:产⽣核⼼dump的Java可执⾏⽂件。
core:需要打印配置信息的核⼼⽂件。
server-id:可选的唯⼀id,如果相同的远程主机上运⾏了多台调试服务器,⽤此选项参数标识服务器。
remote server IP or hostname:远程调试服务器的IP地址或主机名。
  option选项参数说明:
no option:查看进程的内存映像信息。
heap:显⽰Java堆详细信息。
histo[:live]:显⽰堆中对象的统计信息。
permstat:打印类加载器信息。
finalizerinfo:显⽰在F-Queue队列等待Finalizer线程执⾏finalizer⽅法的对象。
dump:<dump-options>:⽣成堆转储快照。
F:当-dump没有响应时,使⽤-dump或者-histo参数,在这个模式下,live⼦参数⽆效。
help:打印帮助信息。
J<flag>:指定传递给运⾏jmap的JVM的参数。
(2)no option⽰例                                             
  命令:jmap pid
  描述:使⽤不带选项参数的jmap打印共享对象映射,将会打印⽬标虚拟机中加载的每个共享对象的起始地址、映射⼤⼩以及共享对象⽂件的路径全称。这与Solaris的pmap⼯具⽐较相似。
(3)heap⽰例                                               
  命令:jmap -heap pid
  描述:打印⼀个堆的摘要信息,包括使⽤的GC算法、堆配置信息和各内存区域内存使⽤信息。
C:\Users\Administrator>jmap -heap 1760
Attaching to process ID 1760,
Debugger attached successfully.
Server compiler detected.
JVM version is 24.80-b11
using thread-local object allocation.                #新⽣代采⽤的是并⾏线程处理⽅式
Parallel GC with 4 thread(s)                        #同步并⾏垃圾回收
Heap Configuration:                                    #堆配置情况,也就是JVM参数配置的结果【平常说的tomcat配置JVM参数,就是在配置这些】
MinHeapFreeRatio = 0                                #最⼩堆使⽤⽐例
MaxHeapFreeRatio = 100                            #最⼤堆可⽤⽐例
MaxHeapSize      = 2147483648 (2048.0MB)            #最⼤堆空间⼤⼩
NewSize          = 1310720 (1.25MB)                #新⽣代分配⼤⼩
MaxNewSize      = 536870912 (512.0MB)            #最⼤可新⽣代分配⼤⼩
OldSize          = 5439488 (5.1875MB)            #⽼年代⼤⼩
NewRatio        = 2                                #新⽣代⽐例
SurvivorRatio    = 8                                #新⽣代与suvivor的⽐例
PermSize        = 21757952 (20.75MB)            #perm区永久代⼤⼩
MaxPermSize      = 2147483648 (2048.0MB)            #最⼤可分配perm区也就是永久代⼤⼩
G1HeapRegionSize = 0 (0.0MB)
Heap Usage:                                            #堆使⽤情况【堆内存实际的使⽤情况】
PS Young Generation
Eden Space:                                            #伊甸区
capacity = 413663232 (394.5MB)                    #伊甸区容量
used    = 41933104 (39.99052429199219MB)        #伊甸区已经使⽤⼤⼩
free    = 371730128 (354.5094757080078MB)        #剩余容量
10.137015029655814% used                            #伊甸区使⽤情况
From Space:                                            #survior1区
capacity = 58195968 (55.5MB)                        #survior1区容量
used    = 0 (0.0MB)                                #surviror1区已使⽤情况
free    = 58195968 (55.5MB)                        #surviror1区剩余容量
0.0% used                                        #survior1区使⽤⽐例
To Space:                                            #survior2区
capacity = 56623104 (54.0MB)                        #survior2区容量
used    = 0 (0.0MB)                                #survior2区已使⽤情况
free    = 56623104 (54.0MB)                        #survior2区剩余容量
0.0% used                                        #survior2区使⽤⽐例
PS Old Generation                                    #⽼年代使⽤情况
capacity = 458227712 (437.0MB)                    #⽼年代容量
used    = 243170504 (231.90546417236328MB)        #⽼年代已使⽤容量
free    = 215057208 (205.09453582763672MB)        #⽼年代剩余容量
53.0676119387559% used                            #⽼年代使⽤⽐例
PS Perm Generation                                    #永久代使⽤情况
capacity = 176685056 (168.5MB)                    #perm区容量
used    = 92300856 (88.02495574951172MB)        #perm区已使⽤容量
free    = 84384200 (80.47504425048828MB)        #perm区剩余容量
52.240329821668674% used                            #perm区使⽤⽐例
62625 interned Strings occupying 7287440 bytes.
View Code
(4)histo[:live]⽰例                                           
  命令:jmap -histo:live pid
  描述:包括每个Java类、对象数量、内存⼤⼩(单位:字节)、完全限定的类名。打印的虚拟机内部的类名称将会带有⼀个'*'前缀。如果指定了live⼦选项,则只计算活动的对象。
(5)permstat⽰例                                             
  命令:jmap -permstat pid
  描述:打印Java堆内存的永久保存区域的类加载器的智能统计信息。对于每个类加载器⽽⾔,它的名称、活跃度、地址、⽗类加载器、它所加载的类的数量和⼤⼩都会被打印。此外,包含的字符串数量和⼤⼩也会被打印。
  注意:该命令会造成tomcat进程挂起。
(6)finalizerinfo⽰例                                           
  命令:jmap -finalizerinfo pid
  描述:打印等待终结的对象信息。
  Number of objects pending for finalization: 0,说明当前F-QUEUE队列中并没有等待Fializer线程执⾏final。
(7)dump:<dump-options>⽰例                                     
  dump-options主要有:
live:只dump存活的对象,如果不加则会dump所有对象。
format=b:表⽰以⼆进制格式。
file=filepath:输出到某个⽂件中。
  命令:jmap -dump:live,format=b,file=⽂件名.txt Pid
(8)F⽰例                                                 
jvm调优参数  与-dump 和-histo⼀起使⽤,强制执⾏后者jmap -F -dump:live,format=b,file=⽂件名称.txt Pid
(9)help⽰例                                               
  打印辅助信息。
(10)J<flag>⽰例                                             
  传递参数给jmap启动的jvm。