JVM——jstat命令

 

概述

Jstat是JDK自带的一个轻量级小工具。全称“Java Virtual Machine statistics monitoring tool”,它位于java的bin目录下,

主要利用JVM内建的指令对Java应用程序的资源和性能进行实时的命令行的监控,包括了对Heap size和垃圾回收状况的监控。

 

jstat 用法

[root@push ~]# 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 参数选项:

[root@push ~]# jstat -options
-class
-compiler
-gc
-gccapacity
-gccause
-gcmetacapacity
-gcnew
-gcnewcapacity
-gcold
-gcoldcapacity
-gcutil
-printcompilation
  • -class: 显示ClassLoad的相关信息;
  • -compiler: 显示JIT编译的相关信息;
  • -gc: 显示和gc相关的堆信息;
  • -gccapacity:    显示各个代的容量以及使用情况;
  • -gcmetacapacity: 显示metaspace的大小
  • -gcnew: 显示新生代信息;
  • -gcnewcapacity: 显示新生代大小和使用情况;
  • -gcold: 显示老年代和永久代的信息;
  • -gcoldcapacity: 显示老年代的大小;
  • -gcutil:   显示垃圾收集信息;
  • -gccause: 显示垃圾回收的相关信息(通-gcutil),同时显示最后一次或当前正在发生的垃圾回收的诱因;
  • -printcompilation: 输出JIT编译的方法信息;
 

JVM内存布局

想要明白jstat命令输出结果的含义,先看一张图,这张图很清晰的说明JVM内存结构的布局和相应的控制参数:

可以看出:

  • 堆内存 = 年轻代 + 年老代

  • 年轻代 = Eden区 + 两个Survivor区(From和To)

现在来解释各列的含义:

  • S0C、S1C、S0U、S1U:Survivor 0/1区容量(Capacity)和使用量(Used)

  • EC、EU:Eden区容量和使用量

  • OC、OU:年老代容量和使用量

  • PC、PU:永久代容量和使用量

  • YGC、YGT:年轻代GC次数和GC耗时

  • FGC、FGCT:Full GC次数和Full GC耗时 GCT:GC总耗时

 

示例一:-class

命令:jstat -class <pid>

描述:显示加载class的数量,及所占空间等信息。

说明:

  • Loaded : 已经装载的类的数量
  • Bytes : 装载类所占用的字节数,以KB为单位
  • Unloaded:已经卸载类的数量
  • Bytes:卸载类的字节数,以KB为单位
  • Time:装载和卸载类所花费的时间

 

示例二: -compiler

命令:jstat -compiler <pid>

描述:显示VM实时编译(JIT)的数量等信息。

说明:

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

示例三: -gc

命令:jstat -gc <pid>

描述:显示gc相关的堆信息,查看gc的次数,及时间。

说明:

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

示例四: -gccapacity

命令:jstat -gccapacity <pid>

描述:显示VM内存中三代(young,old,perm)对象的使用和占用大小。

说明:

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

示例五:-gcmetacapacity

命令:jstat -gcmetacapacity <pid>

描述:metaspace 中对象的信息及其占用量。

说明:

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

示例六: -gcnew

命令:jstat -gcnew <pid>

描述:年轻代中对象的信息及其占用量。

说明:

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

示例七: -gcnewcapacity

命令:jstat -gcnewcapacity <pid>

描述:年轻代对象的信息及其占用量。

说明:

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

示例八: -gcold

命令:jstat -gcold <pid>

描述:老年代对象的信息。

说明:

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

示例九:-gcoldcapacity

命令:jstat -gcoldcapacity <pid>

描述:老年代对象的信息及占用量。

说明:

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

示例十: - gcutil

命令:jstat -gcutil <pid>

描述:统计gc信息。

说明:

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

示例十一:-gccause

命令:jstat -gccause <pid>

描述:统计gc信息。

说明:

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

 


引用:
  • https://www.jianshu.com/p/213710fb9e40

posted on 2021-05-20 10:33  曹伟雄  阅读(1152)  评论(0编辑  收藏  举报

导航