【JVM】基础工具和命令
文章目录
jps
列出在运行的虚拟机进程
jps [option] [hostid]
-q 只输出LVMID 省略主类名称
-m 传递虚拟机进程启动时传给主类main()函数的参数
-l 输出主类名称,JAR包的话输出路径
-v 输出虚拟机进程启动时的JVM参数
多个选项可以一起用
jstat
监视虚拟机各种运行状态信息的命令行工具,显示类加载、内存、垃圾回收、即时编译等运行时数据。 可视化JMC、VisualVM。
jstat -<option> [-t] [-h<lines>] <vmid> [<interval> [<count>]]
S0C:第一个幸存区的大小
S1C:第二个幸存区的大小
S0U:第一个幸存区的使用大小
S1U:第二个幸存区的使用大小
EC:伊甸园区的大小
EU:伊甸园区的使用大小
OC:老年代大小
OU:老年代使用大小
MC:方法区大小
MU:方法区使用大小
CCSC:压缩类空间大小
CCSU:压缩类空间使用大小
YGC:年轻代垃圾回收次数
YGCT:年轻代垃圾回收消耗时间
FGC:老年代垃圾回收次数
FGCT:老年代垃圾回收消耗时间
GCT:垃圾回收消耗总时间
更详细参数参考别人博客 https://zhuanlan.zhihu.com/p/476375396
jinfo
实时查看和调整虚拟机各项参数
jinfo [option] pid
查看未被显式指定的参数的系统默认值
jinfo -flag
JDK6以上可用
java -XX:+PrintFlagsFinal
jmap
生成堆转储快照(headdump 或dump文件),查询finalize执行队列、Java堆和方法区详细信息。
jmap [option] vmid
option | 作用 |
---|---|
-dump:[live,]format=b,file= <filename> | 生成堆转储快照,live是可选参数,如果指定,则只转储堆中的活动对象。 |
-finalizerinfo | 在F-Queue中等待呗Finalizer线程执行finalize方法的对象 |
-heap | 堆详细信息 |
可参考其他博客:
https://zhuanlan.zhihu.com/p/475571429
jhat
分析jmap,不过不建议使用,JDK9的时候已经删除了
建议使用 Eclipse Memory Analyzer Tool (MAT) 和 VisualVM。
jstack
生成线程快照,定位线程长时间停顿的原因
jstack [option] vmid
option | 作用 |
---|---|
-F | 正常输出不被响应,强制输出 |
-l | 除堆栈,显示关于锁的附加信息 |
-m | 调用本地方法的话,显示c\c++的堆栈 |
jdk5以上可以通过Thread.getAllStackTraces()方法获取StackTraceElement,来代替jstack方法。
public class Jstack {
public static void main(String[] args) {
Map<Thread, StackTraceElement[]> m = Thread.getAllStackTraces();
for(Map.Entry<Thread, StackTraceElement[]> en:m.entrySet()) {
Thread t = en.getKey();
StackTraceElement[] v = en.getValue();
System.out.println("Thread name is " + t.getName());
for(StackTraceElement s : v) {
System.out.println("\t" + s.toString());
}
}
}
}