一、簡介:
命令jmap是一個多功能的命令。它可以生成 java 程序的 dump 文件, 也可以查看堆內對象示例的統計信息、查看 ClassLoader 的信息以及 finalizer 隊列。
二、使用:
參數:
- option: 選項參數。
- pid: 需要打印配置信息的進程ID。
- executable: 產生核心dump的Java可執行文件。
- core: 需要打印配置信息的核心文件。
- server-id 可選的唯一id,如果相同的遠程主機上運行了多台調試服務器,用此選項參數標識服務器。
- remote server IP or hostname 遠程調試服務器的IP地址或主機名。
option
- no option: 查看進程的內存映像信息,類似 Solaris pmap 命令。
- heap: 顯示Java堆詳細信息
- histo[:live]: 顯示堆中對象的統計信息
- clstats:打印類加載器信息
- finalizerinfo: 顯示在F-Queue隊列等待Finalizer線程執行finalizer方法的對象
- dump:<dump-options>:生成堆轉儲快照
- F: 當-dump沒有響應時,使用-dump或者-histo參數. 在這個模式下,live子參數無效.
- help:打印幫助信息
- J<flag>:指定傳遞給運行jmap的JVM的參數
示例一:no option
命令:jmap pid
描述:查看進程的內存映像信息,類似 Solaris pmap 命令。
使用不帶選項參數的jmap打印共享對象映射,將會打印目標虛擬機中加載的每個共享對象的起始地址、映射大小以及共享對象文件的路徑全稱。這與Solaris的pmap工具比較相似。

示例二:heap
命令:jmap -heap pid
描述:顯示Java堆詳細信息
打印一個堆的摘要信息,包括使用的GC算法、堆配置信息和各內存區域內存使用信息
示例三:histo[:live]
命令:jmap -histo:live pid
描述:顯示堆中對象的統計信息
其中包括每個Java類、對象數量、內存大小(單位:字節)、完全限定的類名。打印的虛擬機內部的類名稱將會帶有一個’*’前綴。如果指定了live子選項,則只計算活動的對象。

示例四:clstats
命令:jmap -clstats pid
描述:打印類加載器信息
-clstats是-permstat的替代方案,在JDK8之前,-permstat用來打印類加載器的數據
打印Java堆內存的永久保存區域的類加載器的智能統計信息。對於每個類加載器而言,它的名稱、活躍度、地址、父類加載器、它所加載的類的數量和大小都會被打印。此外,包含的字符串數量和大小也會被打印。

示例五:finalizerinfo
命令:jmap -finalizerinfo pid
描述:打印等待終結的對象信息
Number of objects pending for finalization: 0 說明當前F-QUEUE隊列中並沒有等待Fializer線程執行final
示例六:dump:<dump-options>
命令:jmap -dump:format=b,file=heapdump.phrof pid
描述:生成堆轉儲快照dump文件。你可以使用jhat(Java堆分析工具)讀取生成的文件。
這個命令執行,JVM會將整個heap的信息dump寫入到一個文件,heap如果比較大的話,就會導致這個過程比較耗時,並且執行的過程中為了保證dump的信息是可靠的,所以會暫停應用, 線上系統慎用。