命令jmap是一個多功能的命令。它能夠生成 java 程序的 dump 文件, 也能夠查看堆內對象示例的統計信息、查看 ClassLoader 的信息以及 finalizer 隊列。java
命令:jmap pid
描述:查看進程的內存映像信息,相似 Solaris pmap 命令。算法
使用不帶選項參數的jmap打印共享對象映射,將會打印目標虛擬機中加載的每一個共享對象的起始地址、映射大小以及共享對象文件的路徑全稱。這與Solaris的pmap工具比較類似。服務器
命令:jmap -heap pid
描述:顯示Java堆詳細信息工具
打印一個堆的摘要信息,包括使用的GC算法、堆配置信息和各內存區域內存使用信息spa
C:\Users\jjs>jmap -heap 5932 Attaching to process ID 5932, please wait... Debugger attached successfully. Server compiler detected. JVM version is 25.91-b15 using thread-local object allocation. Parallel GC with 4 thread(s) Heap Configuration: MinHeapFreeRatio = 0 MaxHeapFreeRatio = 100 MaxHeapSize = 1073741824 (1024.0MB) NewSize = 42991616 (41.0MB) MaxNewSize = 357564416 (341.0MB) OldSize = 87031808 (83.0MB) NewRatio = 2 SurvivorRatio = 8 MetaspaceSize = 21807104 (20.796875MB) CompressedClassSpaceSize = 1073741824 (1024.0MB) MaxMetaspaceSize = 17592186044415 MB G1HeapRegionSize = 0 (0.0MB) Heap Usage: PS Young Generation Eden Space: capacity = 60293120 (57.5MB) used = 44166744 (42.120689392089844MB) free = 16126376 (15.379310607910156MB) 73.25337285580842% used From Space: capacity = 5242880 (5.0MB) used = 0 (0.0MB) free = 5242880 (5.0MB) 0.0% used To Space: capacity = 14680064 (14.0MB) used = 0 (0.0MB) free = 14680064 (14.0MB) 0.0% used PS Old Generation capacity = 120061952 (114.5MB) used = 19805592 (18.888084411621094MB) free = 100256360 (95.6119155883789MB) 16.496143590935453% used 20342 interned Strings occupying 1863208 bytes.
命令:jmap -histo:live pid
描述:顯示堆中對象的統計信息線程
其中包括每一個Java類、對象數量、內存大小(單位:字節)、徹底限定的類名。打印的虛擬機內部的類名稱將會帶有一個’*’前綴。若是指定了live子選項,則只計算活動的對象。調試
命令:jmap -clstats pid
描述:打印類加載器信息code
-clstats是-permstat的替代方案,在JDK8以前,-permstat用來打印類加載器的數據
打印Java堆內存的永久保存區域的類加載器的智能統計信息。對於每一個類加載器而言,它的名稱、活躍度、地址、父類加載器、它所加載的類的數量和大小都會被打印。此外,包含的字符串數量和大小也會被打印。orm
命令:jmap -finalizerinfo pid
描述:打印等待終結的對象信息server
Number of objects pending for finalization: 0 說明當前F-QUEUE隊列中並無等待Fializer線程執行final
命令:jmap -dump:format=b,file=heapdump.phrof pid
描述:生成堆轉儲快照dump文件。
以hprof二進制格式轉儲Java堆到指定filename的文件中。live子選項是可選的。若是指定了live子選項,堆中只有活動的對象會被轉儲。想要瀏覽heap dump,你可使用jhat(Java堆分析工具)讀取生成的文件。
這個命令執行,JVM會將整個heap的信息dump寫入到一個文件,heap若是比較大的話,就會致使這個過程比較耗時,而且執行的過程當中爲了保證dump的信息是可靠的,因此會暫停應用, 線上系統慎用。