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, please wait...
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示例

  與-dump 和-histo一起使用,強制執行后者jmap -F -dump:live,format=b,file=文件名稱.txt Pid

(9)help示例

  打印輔助信息。

(10)J<flag>示例

  傳遞參數給jmap啟動的jvm。


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM