JDK自带的虚拟机性能监控、故障处理工具

JDK自带的虚拟机性能监控、故障处理工具

Laughing
2025-04-18 / 0 评论 / 8 阅读 / 搜一下 / 正在检测是否收录...

Java在个版本的JDK中为我们提供了各种JVM性能监控及故障处理的小程序,当然,随着JDK版本的迭代,这些小工具的数量和功能也在不知不觉的增加与增强。本文我们会介绍JDK自带的摘日常开发过程中常用的监控虚拟机运行状态和故障处理的工具。

jps命令与Linux下的ps命令类似,可以列示当前正在运行的虚拟机进程,并显示虚拟机进程的主类名称以及泽泻进程本地虚拟机唯一的ID(LVMID),后续我们介绍的工具,大都需要提供虚拟机的LVMID。

对于本地虚拟机而言,LVMID与操作系统的进程ID是一致的。

jps命令格式

jps [option] [hostid]

jps工具组要选项

 选项 擢用
 -q 只输出LVMID,省略主类的名称
 -m 输出虚拟机进程启动时传输主类main()函数的参数 
 -l 输出主类的全称,如果执行的是JAR包,则输出JAR包路径 
 -v 输出虚拟机集成启动时的JVM参数 

当然我们常用的就是jps -l命令,输出所有信息。

m9lgubgf.png

jstat用于监视虚拟机各种运行状态信息,可以显示本地或者远程虚拟机进程中的类加载、内存、垃圾回收、即时编译等运行时数据。

jstat命令格式

jstat [option] [lvmid] [internal] [count]

option是各类参数
lvmid是虚拟机进程的ID,也就是我们jps查询出的ID
internal是间隔多长时间刷新一次
count是一共刷新的次数

 选项 作用
 -class  监视类加载、卸载信息、总空间以及类装载耗时 
 -gc  监视Java堆状况,包括Eden区、2个Survivor区,老年带、永久带的容量,已使用空间、垃圾收集时间合计等信息 
-gccapacity监视内容与-gc基本相同,单输出内容主要关注Java堆各个区域使用到的最大、最小空间
-gcutil监视内容基本与-gc相同,但输出内容主要关注已使用空间占总空间的百分比
-gccause与-gcutil功能一样,但是会额外输出导致上一次垃圾回收的原因
-gcnew监视新生代垃圾收集情况
-gcnewcapacity监视内容与-gcnew基本相同,输出主要关注使用的最大、最小空间
-gcold监视老年代垃圾收集情况
-gcoldcapacity监视内容与-gcold基本相同,输出主要关注使用的最大、最小空间
-gcmetacapacity元空间的最大、最小空间
-compiler输出即时编译器编译过的方法、耗时等信息
-printcompiilation输出已经被即时编译的方法

-class类加载统计

jstat -class 24272

m9m32cbu.png

  • Loaded:加载class的数量
  • Bytes:所占用空间大小
  • Unloaded:未加载数量
  • Bytes:未加载占用空间
  • Time:时间

-gc垃圾回收统计

jstat -gc 24272

m9m2xx98.png

  • S0C:第一个幸存区的大小
  • S1C:第二个幸存区的大小
  • S0U:第一个幸存区的使用大小
  • S1U:第二个幸存区的使用大小
  • EC:伊甸园区的大小
  • EU:伊甸园区的使用大小
  • OC:老年代大小
  • OU:老年代使用大小
  • MC:方法区大小
  • MU:方法区使用大小
  • CCSC:压缩类空间大小
  • CCSU:压缩类空间使用大小
  • YGC:年轻代垃圾回收次数
  • YGCT:年轻代垃圾回收消耗时间
  • FGC:老年代垃圾回收次数
  • FGCT:老年代垃圾回收消耗时间
  • GCT:垃圾回收消耗总时间

-gccapacity堆内存统计

jstat -gccapacity 24272

m9m38rpp.png

  • NGCMN:新生代最小容量
  • NGCMX:新生代最大容量
  • NGC:当前新生代容量
  • S0C:第一个幸存区大小
  • S1C:第二个幸存区的大小
  • EC:伊甸园区的大小
  • OGCMN:老年代最小容量
  • OGCMX:老年代最大容量
  • OGC:当前老年代大小
  • OC:当前老年代大小
  • MCMN:最小元数据容量
  • MCMX:最大元数据容量
  • MC:当前元数据空间大小
  • CCSMN:最小压缩类空间大小
  • CCSMX:最大压缩类空间大小
  • CCSC:当前压缩类空间大小
  • YGC:年轻代gc次数
  • FGC:老年代GC次数

-gcutil堆内存占比统计

jstat -gcutil 24272

m9m3qj18.png

  • S0:幸存1区当前使用比例
  • S1:幸存2区当前使用比例
  • E:伊甸园区使用比例
  • O:老年代使用比例
  • M:元数据区使用比例
  • CCS:压缩使用比例
  • YGC:年轻代垃圾回收次数
  • FGC:老年代垃圾回收次数
  • FGCT:老年代垃圾回收消耗时间
  • GCT:垃圾回收消耗总时间

-gcnew新生代垃圾回收统计

jstat -gcnew 24272

m9m3u77o.png

  • S0C:第一个幸存区大小
  • S1C:第二个幸存区的大小
  • S0U:第一个幸存区的使用大小
  • S1U:第二个幸存区的使用大小
  • TT:对象在新生代存活的次数
  • MTT:对象在新生代存活的最大次数
  • DSS:期望的幸存区大小
  • EC:伊甸园区的大小
  • EU:伊甸园区的使用大小
  • YGC:年轻代垃圾回收次数
  • YGCT:年轻代垃圾回收消耗时间

-compiler编译统计

jstat -compiler 24272

m9m3yk6m.png

  • Compiled:编译数量。
  • Failed:失败数量
  • Invalid:不可用数量
  • Time:时间
  • FailedType:失败类型
  • FailedMethod:失败的方法

jinfo(Configuration Info for Java)的作用是实时查看和调整虚拟机各项参数。说是能调整,但是基本也不会有人调整吧,其实主要还是查看参数信息,特别是一些我们没有指定的隐式的默认参数。

-sysprops:查看该进程的全部配置信息

jinfo -sysprops 24272

m9m4xoz0.png

其实会输出很多信息,这里只截取了部分。

-flags:查看曾经赋过值的参数值

jinfo -flags 24272

m9m4z36g.png

-flag: 查看具体参数的值

用法如下

jinfo -flag [options] [lvmid]

比如查看最大堆内存

jinfo -flag MaxHeapSize 24272

m9m515b7.png

jmap主要用于生成堆转储快照,类似与java启动命令的-XX:+HeapDumpOnOutOfMemoryError。除此之外,jmap还可以查询finalize执行队列、Java堆和方法区的想起信息。

选项作用
-dump生成Java堆转储快照,格式为-dump:[live,]format=b,file=>,其中live子参数说明是否只dump出存活的对象
-finalizerinfo显示在F-Queue中等待Finalizer线程执行finalize方法的对象
-heap显示Java堆详细信息
-histo显示堆中对象统计信息,包括类、实例数量、合计容量
-F当虚拟机进程堆-dump选项无响应时,可强制生成dump快照

-dump生成堆转储快照

jmap -dump:format=b,file=test.hsprof 24272

m9m5gdq1.png

然后可以对堆转储快照进行分析。

jstack(Stack Trace for Java)命令用于生成虚拟机当前时刻的线程快照(一般称为threaddump或者javacore文件)。线程快照就是当前虚拟机内每一条线程正在执行的方法堆栈的集合,生成线程快照的目的通常是定位线程出现长时间停顿的原因,如线程间死锁、死循环、请求外部资源导致的长时间挂起等,都是导致线程长时间停顿的常见原因。线程出现停顿时通过jstack来查看各个线程的调用堆栈,就可以获知没有响应的线程到底在后台做些什么事情,或者等待着什么资源。

命令格式

jstack [ option ] lvmid
选项作用
-F当正常输出的请求不被响应时,强制输出线程堆栈
-l出堆栈外,额外显示锁信息
-m如果调用本地方法的话,可以显示C/C++的堆栈
jstack 24272

m9m5plh0.png

0

评论 (0)

取消