JVM虚拟机(八)jstat 命令使用说明

JVM虚拟机(八)jstat 命令使用说明JVM 虚拟机 八 jstat 命令使用说明 jstat 命令详解

大家好,欢迎来到IT知识分享网。

  • 官方文档: https://docs.oracle.com/javase/1.5.0/docs/tooldocs/share/jstat.html

一、简介

1.什么是jstat?

jstat 是 JDK 提供的一个命令行工具,用于监视 Java 虚拟机(JVM)的各种统计信息。

jstat 位于 java 安装目录的 bin 目录下,主要利用 JVM 内建的指令对 java 应用程序的资源和性能进行实时的监控,包括对 JVM 内存中各种堆内存(Heap size)非堆内存(No heap size)的大小及其内存使用量,以及垃圾回收状况的监控。

2.jstat语法及参数说明

jstat 语法格式:jstat <-命令选项> [-t] [-h<lines>] <pid> [<间隔时间/毫秒> [查询次数]]

<>表示必填,[]表示选填)

[root@d2d343b9bebc /]# jstat -help Usage: jstat -help|-options jstat -<option> [-t] [-h<lines>] <vmid> [<interval> [<count>]] Definitions: <option> An option reported by the -options option <vmid> Virtual Machine Identifier. A vmid takes the following form: <lvmid>[@<hostname>[:<port>]] Where <lvmid> is the local vm identifier for the target Java virtual machine, typically a process id; <hostname> is the name of the host running the target Java virtual machine; and <port> is the port number for the rmiregistry on the target host. See the jvmstat documentation for a more complete description of the Virtual Machine Identifier. <lines> Number of samples between header lines. <interval> Sampling interval. The following forms are allowed: <n>["ms"|"s"] Where <n> is an integer and the suffix specifies the units as milliseconds("ms") or seconds("s"). The default units are "ms". <count> Number of samples to take before terminating. -J<flag> Pass <flag> directly to the runtime system. 
  • -option: 参数选项。
  • -t: 可以在打印的列加上 Timestamp 列,用于显示系统运行的时间。
  • -h: 可以在周期性数据输出的时候,指定输出多少行以后输出一次表头。
  • vmid: Virtual Machine ID(进程的 pid)。
  • interval: 执行每次的间隔时间,单位为毫秒。
  • count: 用于指定输出多少次记录,缺省则会一直打印。

其中,-option 可以从下面常用命令中选择。

二、常用命令

为方便展示,以下截图均为 docker 容器中执行结果,容器中只启动了 springboot-demo-0.0.1-SNAPSHOT.jar 一个 java 程序,pid 为 1。

[root@d2d343b9bebc /]# jps 1 springboot-demo-0.0.1-SNAPSHOT.jar 58 Jps 

注意:使用的jdk版本是jdk8。

1.-class:显示加载 class 数量及所占空间

执行结果:

[root@d2d343b9bebc /]# jstat -class 1 Loaded Bytes Unloaded Bytes Time 6146 11132.3 0 0.0 3.22 

信息说明:

  • Loaded:加载类的数量
  • Bytes:加载类的size,单位为Byte
  • Unloaded:卸载类的数目
  • Bytes:卸载类的size,单位为Byte
  • Time:加载与卸载类花费的时间

2.-compiler:显示VM实时编译的数量

执行结果:

[root@d2d343b9bebc /]# jstat -compiler 1 Compiled Failed Invalid Time FailedType FailedMethod 3067 0 0 3.86 0 

信息说明:

  • Compiled:编译任务执行数量
  • Failed:编译任务执行失败数量
  • Invalid:编译任务执行失效数量
  • Time:编译任务消耗时间
  • FailedType:最后一个编译失败任务的类型
  • FailedMethod:最后一个编译失败任务所在的类及方法

3.-gc:显示gc的次数及时间

执行结果:

[root@d2d343b9bebc /]# jstat -gc 1 S0C S1C S0U S1U EC EU OC OU MC MU CCSC CCSU YGC YGCT FGC FGCT GCT 3584.0 2560.0 0.0 2528.0 .0 52927.3 19456.0 7163.8 30720.0 29147.5 4096.0 3769.9 11 0.047 1 0.038 0.085 

信息说明:

  • S0C:年轻代中第一个survivor(幸存区)的容量 (字节)
  • S1C:年轻代中第二个survivor(幸存区)的容量 (字节)
  • S0U:年轻代中第一个survivor(幸存区)目前已使用空间 (字节)
  • S1U:年轻代中第二个survivor(幸存区)目前已使用空间 (字节)
  • EC:年轻代中Eden(伊甸园)的容量 (字节)
  • EU:年轻代中Eden(伊甸园)目前已使用空间 (字节)
  • OC:老年代的容量 (字节)
  • OU:老年代目前已使用空间 (字节)
  • MC:metaspace(元空间)的容量 (字节)
  • MU:metaspace(元空间)目前已使用空间 (字节)
  • CCSC:当前压缩类空间的容量 (字节)
  • CCSU:当前压缩类空间目前已使用空间 (字节)
  • YGC:从应用程序启动到采样时年轻代中gc次数
  • YGCT:从应用程序启动到采样时年轻代中gc所用时间(s)
  • FGC:从应用程序启动到采样时老年代(全gc)gc次数
  • FGCT:从应用程序启动到采样时老年代(全gc)gc所用时间(s)
  • GCT:从应用程序启动到采样时gc用的总时间(s)

4.-gccapacity:显示VM内存中三代(young/old/perm)对象的使用和占用大小

执行结果:

[root@d2d343b9bebc /]# jstat -gccapacity 1 NGCMN NGCMX NGC S0C S1C EC OGCMN OGCMX OGC OC MCMN MCMX MC CCSMN CCSMX CCSC YGC FGC 10240.0 .0 .0 3584.0 2560.0 .0 20480.0 .0 19456.0 19456.0 0.0 .0 30720.0 0.0 .0 4096.0 11 1 

信息说明:

  • NGCMN:年轻代(young)中初始化(最小)的大小(字节)
  • NGCMX:年轻代(young)的最大容量 (字节)
  • NGC:年轻代(young)中当前的容量 (字节)
  • S0C:年轻代中第一个survivor(幸存区)的容量 (字节)
  • S1C:年轻代中第二个survivor(幸存区)的容量 (字节)
  • EC:年轻代中Eden(伊甸园)的容量 (字节)
  • OGCMN:老年代中初始化(最小)的容量大小 (字节)
  • OGCMX:老年代的最大容量(字节)
  • OGC:老年代当前新生成的容量 (字节)
  • OC:老年代的容量 (字节)
  • MCMN:metaspace(元空间)中初始化(最小)的大小 (字节)
  • MCMX:metaspace(元空间)的最大容量 (字节)
  • MC:metaspace(元空间)当前新生成的容量 (字节)
  • CCSMN:最小压缩类空间大小
  • CCSMX:最大压缩类空间大小
  • CCSC:当前压缩类空间大小
  • YGC:从应用程序启动到采样时年轻代中gc次数
  • FGC:从应用程序启动到采样时老年代(全gc)gc次数

5.-gcmetacapacity:显示元数据空间统计

执行结果:

[root@d2d343b9bebc /]# jstat -gcmetacapacity 1 MCMN MCMX MC CCSMN CCSMX CCSC YGC FGC FGCT GCT 0.0 .0 30720.0 0.0 .0 4096.0 11 1 0.038 0.085 

信息说明:

  • MCMN:最小元数据容量
  • MCMX:最大元数据容量
  • MC:当前元数据空间大小
  • CCSMN:最小压缩类空间大小
  • CCSMX:最大压缩类空间大小
  • CCSC:当前压缩类空间大小
  • YGC:从应用程序启动到采样时年轻代中gc次数
  • FGC:从应用程序启动到采样时老年代(全gc)gc次数
  • FGCT:从应用程序启动到采样时老年代(全gc)gc所用时间(s)
  • GCT:从应用程序启动到采样时gc用的总时间(s)

6.-gcnew:显示年轻代对象的信息

执行结果:

[root@d2d343b9bebc /]# jstat -gcnew 1 S0C S1C S0U S1U TT MTT DSS EC EU YGC YGCT 3584.0 2560.0 0.0 2528.0 1 15 3584.0 .0 52927.3 11 0.047 

信息说明:

  • S0C:年轻代中第一个survivor(幸存区)的容量 (字节)
  • S1C:年轻代中第二个survivor(幸存区)的容量 (字节)
  • S0U:年轻代中第一个survivor(幸存区)目前已使用空间 (字节)
  • S1U:年轻代中第二个survivor(幸存区)目前已使用空间 (字节)
  • TT:持有次数限制
  • MTT:最大持有次数限制
  • DSS:期望的幸存区大小
  • EC:年轻代中Eden(伊甸园)的容量 (字节)
  • EU:年轻代中Eden(伊甸园)目前已使用空间 (字节)
  • YGC:从应用程序启动到采样时年轻代中gc次数
  • YGCT:从应用程序启动到采样时年轻代中gc所用时间(s)

7.-gcnewcapacity:显示年轻代对象的信息及其占用量

执行结果:

[root@d2d343b9bebc /]# jstat -gcnewcapacity 1 NGCMN NGCMX NGC S0CMX S0C S1CMX S1C ECMX EC YGC FGC 10240.0 .0 .0 54272.0 3584.0 54272.0 2560.0 .0 .0 11 1 

信息说明:

  • NGCMN:年轻代(young)中初始化(最小)的大小(字节)
  • NGCMX:年轻代(young)的最大容量 (字节)
  • NGC:年轻代(young)中当前的容量 (字节)
  • S0CMX:年轻代中第一个survivor(幸存区)的最大容量 (字节)
  • S0C:年轻代中第一个survivor(幸存区)的容量 (字节)
  • S1CMX:年轻代中第二个survivor(幸存区)的最大容量 (字节)
  • S1C:年轻代中第二个survivor(幸存区)的容量 (字节)
  • ECMX:年轻代中Eden(伊甸园)的最大容量 (字节)
  • EC:年轻代中Eden(伊甸园)的容量 (字节)
  • YGC:从应用程序启动到采样时年轻代中gc次数
  • FGC:从应用程序启动到采样时old代(全gc)gc次数

8.-gcold:显示老年代对象的信息

执行结果:

[root@d2d343b9bebc /]# jstat -gcold 1 MC MU CCSC CCSU OC OU YGC FGC FGCT GCT 30720.0 29147.5 4096.0 3769.9 19456.0 7163.8 11 1 0.038 0.085 

信息说明:

  • MC:metaspace(元空间)的容量 (字节)
  • MU:metaspace(元空间)目前已使用空间 (字节)
  • CCSC:压缩类空间大小
  • CCSU:压缩类空间使用大小
  • OC:Old代的容量 (字节)
  • OU:Old代目前已使用空间 (字节)
  • YGC:从应用程序启动到采样时年轻代中gc次数
  • FGC:从应用程序启动到采样时old代(全gc)gc次数
  • FGCT:从应用程序启动到采样时old代(全gc)gc所用时间(s)
  • GCT:从应用程序启动到采样时gc用的总时间(s)

9.-gcoldcapacity:显示老年代对象的信息及其占用量

执行结果:

[root@d2d343b9bebc /]# jstat -gcoldcapacity 1 OGCMN OGCMX OGC OC YGC FGC FGCT GCT 20480.0 .0 19456.0 19456.0 11 1 0.038 0.085 

信息说明:

  • OGCMN:old代中初始化(最小)的大小 (字节)
  • OGCMX:old代的最大容量(字节)
  • OGC:old代当前新生成的容量 (字节)
  • OC:Old代的容量 (字节)
  • YGC:从应用程序启动到采样时年轻代中gc次数
  • FGC:从应用程序启动到采样时old代(全gc)gc次数
  • FGCT:从应用程序启动到采样时old代(全gc)gc所用时间(s)
  • GCT:从应用程序启动到采样时gc用的总时间(s)

10.-gcutil:统计gc信息百分比

执行结果:

[root@d2d343b9bebc /]# jstat -gcutil 1 S0 S1 E O M CCS YGC YGCT FGC FGCT GCT 0.00 98.75 50.43 36.82 94.88 92.04 11 0.047 1 0.038 0.085 

信息说明:

  • S0:年轻代中第一个survivor(幸存区)已使用的占当前容量百分比
  • S1:年轻代中第二个survivor(幸存区)已使用的占当前容量百分比
  • E:年轻代中Eden(伊甸园)已使用的占当前容量百分比
  • O:old代已使用的占当前容量百分比
  • M:元数据区已使用的占当前容量百分比
  • CCS:压缩类空间已使用的占当前容量百分比
  • YGC :从应用程序启动到采样时年轻代中gc次数
  • YGCT :从应用程序启动到采样时年轻代中gc所用时间(s)
  • FGC :从应用程序启动到采样时old代(全gc)gc次数
  • FGCT :从应用程序启动到采样时old代(全gc)gc所用时间(s)
  • GCT:从应用程序启动到采样时gc用的总时间(s)

11.-gccause:显示最近一次GC统计和原因

执行结果:

[root@d2d343b9bebc /]# jstat -gccause 1 S0 S1 E O M CCS YGC YGCT FGC FGCT GCT LGCC GCC 0.00 98.75 52.76 36.82 94.88 92.04 11 0.047 1 0.038 0.085 Allocation Failure No GC 

信息说明:

  • LGCC:最后一次GC原因
  • GCC:当前GC原因(No GC 为当前没有执行GC)

12.-printcompilation:JVM编译方法统计

执行结果:

[root@d2d343b9bebc /]# jstat -printcompilation 1 Compiled Size Type Method 3110 48 1 java/util/concurrent/ConcurrentHashMap sumCount 

信息说明:

  • Compiled:编译任务的数目
  • Size:方法生成的字节码的大小
  • Type:编译类型
  • Method:类名和方法名用来标识编译的方法。类名使用/做为一个命名空间分隔符。方法名是给定类中的方法。上述格式是由-XX:+PrintComplation选项进行设置的

三、远程监控

jps 一样,jstat 也支持远程监控,同样需要开启安全授权,类似 jps。

 C:\Users\Administrator>jps 192.168.146.128 3346 QuorumPeerMain 3475 Jstatd C:\Users\Administrator>jstat -gcutil 3346@192.168.146.128 S0 S1 E O M CCS YGC YGCT FGC FGCT GCT 52.97 0.00 65.15 13.92 97.39 98.02 8 0.020 0 0.000 0.020 

整理完毕,完结撒花~ 🌻

参考地址:

1.jstat,https://baike.baidu.com/item/jstat/

2.jstat命令详解[通俗易懂],https://cloud.tencent.com/developer/article/

3.jvm 性能调优工具之 jstat 命令详解,https://blog.csdn.net/javalingyu/article/details/

免责声明:本站所有文章内容,图片,视频等均是来源于用户投稿和互联网及文摘转载整编而成,不代表本站观点,不承担相关法律责任。其著作权各归其原作者或其出版社所有。如发现本站有涉嫌抄袭侵权/违法违规的内容,侵犯到您的权益,请在线联系站长,一经查实,本站将立刻删除。 本文来自网络,若有侵权,请联系删除,如若转载,请注明出处:https://haidsoft.com/119126.html

(0)
上一篇 2025-11-07 20:10
下一篇 2025-11-07 20:20

相关推荐

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注微信