jhat
jhat(JVM Heap Analysis Tool)命令是與jmap搭配使用,用來分析jmap生成的dump,jhat內置了一個微型的HTTP/HTML服務器,生成dump的分析結果后,可以在瀏覽器中查看。在此要注意,一般不會直接在服務器上進行分析,因為jhat是一個耗時並且耗費硬件資源的過程,一般把服務器生成的dump文件復制到本地或其他機器上進行分析
語法:
jhat [ options ] heap-dump-file
選項
- -stack false|true 關閉對象分配調用棧跟蹤(tracking object allocation call stack)。 如果分配位置信息在堆轉儲中不可用. 則必須將此標志設置為 false. 默認值為 true.>
- -refs false|true 關閉對象引用跟蹤(tracking of references to objects)。 默認值為 true. 默認情況下, 返回的指針是指向其他特定對象的對象,如反向鏈接或輸入引用(referrers or incoming references), 會統計/計算堆中的所有對象。>
- -port port-number 設置 jhat HTTP server 的端口號. 默認值 7000.>
- -exclude exclude-file 指定對象查詢時需要排除的數據成員列表文件(a file that lists data members that should be excluded from the reachable objects query)。 例如, 如果文件列列出了 java.lang.String.value , 那么當從某個特定對象 Object o 計算可達的對象列表時, 引用路徑涉及 java.lang.String.value 的都會被排除。>
- -baseline exclude-file 指定一個基准堆轉儲(baseline heap dump)。 在兩個 heap dumps 中有相同 object ID 的對象會被標記為不是新的(marked as not being new). 其他對象被標記為新的(new). 在比較兩個不同的堆轉儲時很有用.>
- -debug int 設置 debug 級別. 0 表示不輸出調試信息。 值越大則表示輸出更詳細的 debug 信息.>
- -version 啟動后只顯示版本信息就退出>
- -J< flag > 因為 jhat 命令實際上會啟動一個JVM來執行, 通過 -J 可以在啟動JVM時傳入一些啟動參數. 例如, -J-Xmx512m 則指定運行 jhat 的Java虛擬機使用的最大堆內存為 512 MB. 如果需要使用多個JVM啟動參數,則傳入多個 -Jxxxxxx
[root@node1 ~]# jhat -J-Xmx512m hprof.dump
Reading from hprof.dump... Dump file created Wed Feb 12 16:39:57 CST 2020 Snapshot read, resolving... Resolving 1024621 objects... WARNING: Class fda37e78 not found, adding fake class! WARNING: Class fd2d08d0 not found, adding fake class! WARNING: Class fcf1a358 not found, adding fake class! Chasing references, expect 204 dots............................................................................................................................................................................................................ Eliminating duplicate references............................................................................................................................................................................................................ Snapshot resolved. Started HTTP server on port 7000 Server is ready. 中間的-J-Xmx512m是在dump快照很大的情況下分配512M內存去啟動HTTP服務器,運行完之后就可在瀏覽器打開Http://localhost:7000進行快照分析 堆快照分析主要在最后面的Heap Histogram里,里面根據class列出了dump的時候所有存活對象。 分析同樣一個dump快照,MAT需要的額外內存比jhat要小的多的多,所以建議使用MAT來進行分析,當然也看個人偏好。
瀏覽器頁面最下面有相關功能,一般查看堆異常情況主要看這個兩個部分: Show instance counts for all classes (excluding platform),平台外的所有對象信息。如下圖: