了解JVM虚拟机——jstat基本命令
Posted GYTTking
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了了解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
-printcompilationh
/*欢迎加入
- -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
描述:显示加载class的数量,及所占空间等信息。
说明:
- Loaded : 已经装载的类的数量
- Bytes : 装载类所占用的字节数,以KB为单位
- Unloaded:已经卸载类的数量
- Bytes:卸载类的字节数,以KB为单位
- Time:装载和卸载类所花费的时间
示例二: -compiler
命令:jstat -compiler
描述:显示VM实时编译(JIT)的数量等信息。
说明:
- Compiled:编译任务执行数量
- Failed:编译任务执行失败数量
- Invalid :编译任务执行失效数量
- Time :编译任务消耗时间
- FailedType:最后一个编译失败任务的类型
- FailedMethod:最后一个编译失败任务所在的类及方法
示例三: -gc
命令:jstat -gc
描述:显示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
描述:显示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
描述:metaspace 中对象的信息及其占用量。
说明:
- MCMN:最小元数据容量
- MCMX:最大元数据容量
- MC:当前元数据空间大小
- CCSMN:最小压缩类空间大小
- CCSMX:最大压缩类空间大小
- CCSC:当前压缩类空间大小
- YGC :从应用程序启动到采样时年轻代中gc次数
- FGC :从应用程序启动到采样时old代(全gc)gc次数
- FGCT :从应用程序启动到采样时old代(全gc)gc所用时间(s)
- GCT:从应用程序启动到采样时gc用的总时间(s)
示例六: -gcnew
命令:jstat -gcnew
描述:年轻代中对象的信息及其占用量。
说明:
- 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
描述:年轻代对象的信息及其占用量。
说明:
- 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次数
还有不懂的小伙伴可以添加作者的联系方式
- QQ:1162798594
- vx:tan1999nn
- QQ群:665845932
- 喜欢的小伙伴可以给作者我点点赞,点点关注哈~~~
以上是关于了解JVM虚拟机——jstat基本命令的主要内容,如果未能解决你的问题,请参考以下文章