參考博客:https://www.jianshu.com/p/a4ad53179df3算法
jmap(Memory Map for Java)命令用於生成堆轉儲快照(通常稱爲heapdump或dump文件)。 jmap的做用並不單單是爲了獲取dump文件,它還能夠查詢finalize執行隊列、Java堆和永久代的詳細信息,
如空間使用率、當前用的是哪一種收集器等。和jinfo命令同樣,jmap有很多功能在Windows平臺下都是受限的,
除了生成dump文件的-dump選項和用於查看每一個類的實例、空間佔用統計的-histo選項在全部操做系統都提供以外,其他選項都只能在Linux/Solaris下使用。tomcat
參數:
option: 選項參數。
pid: 須要打印配置信息的進程ID。
executable: 產生核心dump的Java可執行文件。
core: 須要打印配置信息的核心文件。
server-id 可選的惟一id,若是相同的遠程主機上運行了多臺調試服務器,用此選項參數標識服務器。
remote server IP or hostname 遠程調試服務器的IP地址或主機名。服務器
no option: 查看進程的內存映像信息,相似 Solaris pmap 命令。
heap: 顯示Java堆詳細信息
histo[:live]: 顯示堆中對象的統計信息
clstats:打印類加載器信息
finalizerinfo: 顯示在F-Queue隊列等待Finalizer線程執行finalizer方法的對象
dump:<dump-options>:生成堆轉儲快照
F: 當-dump沒有響應時,使用-dump或者-histo參數. 在這個模式下,live子參數無效.
help:打印幫助信息工具
使用不帶選項參數的jmap打印共享對象映射,將會打印目標虛擬機中加載的每一個共享對象的起始地址、映射大小以及共享對象文件的路徑全稱。這與Solaris的pmap工具比較類似。操作系統
顯示Java堆詳細信息,打印一個堆的摘要信息,包括使用的GC算法、堆配置信息和各內存區域內存使用信息線程
執行jmap命令,-dump的參數,啓動tomcat,用jmap命令來生成dump文件,先用jps -l先找出tomcat進程id,而後執行命令:jmap -dump:live,format=b,file=/usr/loca/heap.bin 33201 ,咱們看到在bin目錄下就產生了一個堆的轉存文件。3d
jmap -histo:live pid
描述:顯示堆中對象的統計信息,其中包括每一個Java類、對象數量、內存大小(單位:字節)、徹底限定的類名。打印的虛擬機內部的類名稱將會帶有一個’*’前綴。若是指定了live子選項,則只計算活動的對象。調試
命令:jmap -clstats pid
描述:打印類加載器信息 ,-clstats是-permstat的替代方案,在JDK8以前,-permstat用來打印類加載器的數據
打印Java堆內存的永久保存區域的類加載器的智能統計信息。對於每一個類加載器而言,它的名稱、活躍度、地址、父類加載器、它所加載的類的數量和大小都會被打印。此外,包含的字符串數量和大小也會被打印。orm