Jstat命令

jstat命令可以查看堆内存各部分的使用量,以及加载类的数量。命令的格式如下:

jstat [-命令选项] [vmid] [间隔时间/毫秒] [查询次数] 

GC调优,当前主要是在Java 8下PerNew + CMS可以通过调优来尽可能的减少FGC,但在9引入G1后,调优的点已经发生了变化,在11引入ZGC后更是如此(并发、不再分代),技术迭代。。。。

jstat参数

jstat -h

-h requires an integer argument
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: 用于指定输出多少次记录,缺省则会一直打印

jstat options参数

jstat -options
-class
-compiler
-gc
-gccapacity
-gccause
-gcmetacapacity
-gcnew
-gcnewcapacity
-gcold
-gcoldcapacity
-gcutil

说明:

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

下面的80277是一个使用ZGC的服务,75696是使用G1的IDEA,与之前使用PerNew + CMS的还是有些不同的

类加载统计:-class

jstat -class 80277
Loaded Bytes Unloaded Bytes     Time  
33601 73482.3        2     3.6      41.61

说明

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

编译统计:-compiler

jstat -compiler 80277
Compiled Failed Invalid   Time   FailedType FailedMethod
  45809      3       0    17.88          1 org/aspectj/weaver/World resolveToReferenceType

说明

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

垃圾回收统计:-gc

jstat -gc 80277
S0C   S1C   S0U   S1U   EC   EU   OC   OU   MC   MU   CCSC   CCSU   YGC   YGCT   FGC   FGCT     CGC   CGCT   GCT  
-   -   -   -   -   -   350208.0   342016.0   217664.0   215461.0   25088.0   23991.2   -         -   -   -   105   0.003   0.003

jstat -gc 75696  
S0C   S1C   S0U   S1U   EC   EU   OC   OU   MC   MU   CCSC   CCSU   YGC   YGCT   FGC   FGCT     CGC   CGCT   GCT    
0.0   3072.0   0.0   3072.0   1836032.0   322560.0   1233920.0   885699.9   847308.0   810192.0  113376.0  100405.8   684   35.835   1   1.033   276   13.254   50.122

说明

  • S0C:年轻代中第一个survivor(幸存区)的容量 (字节)
  • S1C:年轻代中第二个survivor(幸存区)的容量 (字节)
  • S0U:年轻代中第一个survivor(幸存区)目前已使用空间 (字节)
  • S1U:年轻代中第二个survivor(幸存区)目前已使用空间 (字节)
  • EC:年轻代中Eden(伊甸园)的容量 (字节)
  • EU:年轻代中Eden(伊甸园)目前已使用空间 (字节)
  • OC:Old代的容量 (字节)
  • OU:Old代目前已使用空间 (字节)
  • MC:metaspace(元空间)的容量 (字节)
  • MU:metaspace(元空间)目前已使用空间 (字节)
  • YGC:从应用程序启动到采样时年轻代中gc次数
  • YGCT:从应用程序启动到采样时年轻代中gc所用时间(s)
  • FGC:从应用程序启动到采样时old代(全gc)gc次数
  • FGCT:从应用程序启动到采样时old代(全gc)gc所用时间(s)
  • CGC:Java 11开始引入的参数,并发垃圾收集次数
  • CGCT:并发gc所用的时间(s)
  • GCT:从应用程序启动到采样时gc用的总时间(s)

堆内存统计:-gccapacity

jstat -gccapacity 75696
NGCMN     NGCMX     NGC     S0C     S1C     EC     OGCMN     OGCMX     OGC     OC     MCMN       MCMX     MC     CCSMN     CCSMX     CCSC     YGC     FGC     CGC
0.0    4194304.0    1839104.0   0.0    3072.0    1836032.0    0.0   4194304.0   1233920.0    1233920.0   0.0   1775616.0   847308.0    0.0   1040384.0  113376.0    684    1   276

说明

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

元空间统计:-gcmetacapacity

jstat -gcmetacapacity  75696
MCMN   MCMX   MC   CCSMN   CCSMX   CCSC   YGC   FGC   FGCT   CGC   CGCT     GCT  
0.0  1777664.0   848460.0    0.0  1040384.0  113504.0   685   1   1.033   278   13.373   50.301

说明

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

新生代垃圾回收统计:-gcnew

jstat -gcnew  75696
S0C   S1C   S0U   S1U     TT   MTT   DSS     EC         EU           YGC   YGCT  
0.0   3072.0   0.0    3072.0  1    15   9728.0    1836032.0    1416192.0    684    35.835

说明

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

新生代内存统计:-gcnewcapacity

jstat -gcnewcapacity    75696
NGCMN     NGCMX     NGC     S0CMX     S0C     S1CMX     S1C     ECMX     EC     YGC   FGC   CGC
0.0    4194304.0    1839104.0      0.0       0.0   4194304.0      3072.0    4194304.0    1836032.0    684     1   276

说明

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

老年代垃圾回收统计:-gcold

jstat -gcold    75696
MC         MU       CCSC     CCSU         OC           OU       YGC   FGC   FGCT     CGC   CGCT       GCT  
848460.0   811147.8  113504.0  100519.3    1211392.0     871481.6    685     1     1.033   278    13.373    50.301

说明

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

老年代内存统计:-gcoldcapacity

jstat -gcoldcapacity  75696
OGCMN     OGCMX         OGC           OC       YGC   FGC   FGCT     CGC   CGCT       GCT  
0.0    4194304.0    1211392.0    1211392.0    685     1     1.033   278    13.373    50.301

说明

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

垃圾收集信息:-gcutil

jstat -gcutil  75696
S0   S1   E     O     M   CCS   YGC     YGCT     FGC   FGCT   CGC   CGCT       GCT  
0.00 100.00  72.90  71.94  95.60  88.56   685   35.895   1    1.033   278   13.373    50.301

说明

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

输出最近一次GC的信息:-gccause

jstat -gccause  75696
S0     S1     E     O     M     CCS   YGC     YGCT     FGC   FGCT     CGC   CGCT       GCT   LGCC       GCC                
 0.00 100.00  78.37  71.94  95.60  88.56    685    35.895     1     1.033   278    13.373    50.301 G1 Humongous Allocation No GC        
 
jstat -gccause 80277
S0     S1     E     O     M     CCS   YGC     YGCT     FGC   FGCT     CGC   CGCT       GCT   LGCC                 GCC                
-      -      -  99.42   98.99  95.63      -         -     -         -   135     0.003     0.003 Proactive     No GC  

说明

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

Leave a Reply

Your email address will not be published. Required fields are marked *

lWoHvYe 无悔,专一