目錄
一、jdk工具之jps(JVM Process Status Tools)命令使用
二、jdk命令之javah命令(C Header and Stub File Generator)
三、jdk工具之jstack(Java Stack Trace)
四、jdk工具之jstat命令(Java Virtual Machine Statistics Monitoring Tool)
四、jdk工具之jstat命令2(Java Virtual Machine Statistics Monitoring Tool)詳解
五、jdk工具之jmap(java memory map)、 mat之四--結合mat對內存泄露的分析
六、jdk工具之jinfo命令(Java Configuration Info)
七、jdk工具之jconsole命令(Java Monitoring and Management Console)
八、jdk工具之JvisualVM、JvisualVM之二--Java程序性能分析工具Java VisualVM
九、jdk工具之jhat命令(Java Heap Analyse Tool)
十、jdk工具之Jdb命令(The Java Debugger)
十一、jdk命令之Jstatd命令(Java Statistics Monitoring Daemon)
十一、jdk命令之Jstatd命令(Java Statistics Monitoring Daemon)
十二、jdk工具之jcmd介紹(堆轉儲、堆分析、獲取系統信息、查看堆外內存)
十三、jdk命令之Java內存之本地內存分析神器:NMT 和 pmap
一、jcmd命令使用
先羅列下jcmd的常見用法:
- 堆直方圖查看:查看系統中類統計信息GC.class_histogram,示例見《Heap堆分析(堆轉儲、堆分析)》
- 堆轉儲:導出堆信息GC.heap_dump,示例見《Heap堆分析(堆轉儲、堆分析)》
- 獲取系統Properties內容VM.system_properties
- 獲取啟動參數VM.flags
- 獲取所有性能相關數據PerfCounter.print
- 查看原生內存信息:jcmd process_id VM.native_memory summary,示例見《原生內存(堆外內存)》
-
查看CompressedClassSpace大小:jcmd pid GC.heap_info
概述
在JDK 1.7之后,新增了一個命令行工具jcmd。它是一個多功能工具,可以用來導出堆,查看Java進程,導出線程信息,執行GC等。
使用示例
下面這個命令能夠列出當前運行的所有虛擬機:

參數-l表示列出所有java虛擬機,針對每一個虛擬機,可以使用help命令列出該虛擬機支持的所有命令,如下圖所示,以8152這個進程為例:


查看虛擬機啟動時間VM.uptime

打印線程棧信息Thread.print

查看系統中類統計信息GC.class_histogram
執行如下命令:
C:\Users\lenovo>jcmd 8152 GC.class_histogram
得到結果如下:

導出堆信息GC.heap_dump
使用如下命令可以導出當前堆棧信息,這個命令功能和 jmap -dump
功能一樣

獲取系統Properties內容VM.system_properties

獲取啟動參數VM.flags

獲取所有性能相關數據PerfCounter.print

6、查看原生內存信息:jcmd process_id VM.native_memory summary
docker下執行如下:

NMT(native memory tracking)
使用
在JVM參數中添加 -XX:NativeMemoryTracking=[off | summary | detail]
-XX:NativeMemoryTracking=detail
在JVM運行過程中,使用jcmd獲取相關信息
jcmd pid VM.native_memory [summary | detail | baseline | summary.diff | detail.diff | shutdown] [scale= KB | MB | GB]
jcmd pid VM.native_memory detail
baseline個基准,之后會輸出diff參數,來和這個基線版本進行比較,可以兩次的內存差
總結
從以上示例可以看出,jcmd擁有jmap的大部分功能,並且Oracle官方也建議使用jcmd代替jmap。
