【JVM命令系列】jstat
命令基本概述
Jstat是JDK自带的一个轻量级小工具。全称“Java Virtual Machine statistics monitoring tool”,它位于java的bin目录下,主要利用JVM内建的指令对Java应用程序的资源和性能进行实时的命令行的监控,包括了对Heap size和垃圾回收状况的监控。可见,Jstat是轻量级的、专门针对JVM的工具,非常适用。
命令格式
jstat工具特别强大,有众多的可选项,详细查看堆内各个部分的使用量,以及加载类的数量。使用时,需加上查看进程的进程id,和所选参数。参考格式如下:
jstat -options
可以列出当前JVM版本支持的选项,常见的有
- l class (类加载器)
- l compiler (JIT)
- l gc (GC堆状态)
- l gccapacity (各区大小)
- l gccause (最近一次GC统计和原因)
- l gcnew (新区统计)
- l gcnewcapacity (新区大小)
- l gcold (老区统计)
- l gcoldcapacity (老区大小)
- l gcpermcapacity (永久区大小)
- l gcutil (GC统计汇总)
- l printcompilation (HotSpot编译统计)
参数说明
1、jstat –class<pid> : 显示加载class的数量,及所占空间等信息。
|
显示列名 |
具体描述 |
|
Loaded |
装载的类的数量 |
|
Bytes |
装载类所占用的字节数 |
|
Unloaded |
卸载类的数量 |
|
Bytes |
卸载类的字节数 |
|
Time |
装载和卸载类所花费的时间 |
2、jstat -compiler <pid>显示VM实时编译的数量等信息。
|
显示列名 |
具体描述 |
|
Compiled |
编译任务执行数量 |
|
Failed |
编译任务执行失败数量 |
|
Invalid |
编译任务执行失效数量 |
|
Time |
编译任务消耗时间 |
|
FailedType |
最后一个编译失败任务的类型 |
|
FailedMethod |
最后一个编译失败任务所在的类及方法 |
3、jstat -gc <pid>: 可以显示gc的信息,查看gc的次数,及时间。
|
显示列名 |
具体描述 |
|
S0C |
年轻代中第一个survivor(幸存区)的容量 (字节) |
|
S1C |
年轻代中第二个survivor(幸存区)的容量 (字节) |
|
S0U |
年轻代中第一个survivor(幸存区)目前已使用空间 (字节) |
|
S1U |
年轻代中第二个survivor(幸存区)目前已使用空间 (字节) |
|
EC |
年轻代中Eden(伊甸园)的容量 (字节) |
|
EU |
年轻代中Eden(伊甸园)目前已使用空间 (字节) |
|
OC |
Old代的容量 (字节) |
|
OU |
Old代目前已使用空间 (字节) |
|
PC |
Perm(持久代)的容量 (字节) |
|
PU |
Perm(持久代)目前已使用空间 (字节) |
|
YGC |
从应用程序启动到采样时年轻代中gc次数 |
|
YGCT |
从应用程序启动到采样时年轻代中gc所用时间(s) |
|
FGC |
从应用程序启动到采样时old代(全gc)gc次数 |
|
FGCT |
从应用程序启动到采样时old代(全gc)gc所用时间(s) |
|
GCT |
从应用程序启动到采样时gc用的总时间(s) |
4、jstat -gccapacity <pid>:可以显示,VM内存中三代(young,old,perm)对象的使用和占用大小
|
显示列名 |
具体描述 |
|
NGCMN |
年轻代(young)中初始化(最小)的大小(字节) |
|
NGCMX |
年轻代(young)的最大容量 (字节) |
|
NGC |
年轻代(young)中当前的容量 (字节) |
|
S0C |
年轻代中第一个survivor(幸存区)的容量 (字节) |
|
S1C |
年轻代中第二个survivor(幸存区)的容量 (字节) |
|
EC |
年轻代中Eden(伊甸园)的容量 (字节) |
|
OGCMN |
old代中初始化(最小)的大小 (字节) |
|
OGCMX |
old代的最大容量(字节) |
|
OGC |
old代当前新生成的容量 (字节) |
|
OC |
Old代的容量 (字节) |
|
PGCMN |
perm代中初始化(最小)的大小 (字节) |
|
PGCMX |
perm代的最大容量 (字节) |
|
PGC |
perm代当前新生成的容量 (字节) |
|
PC |
Perm(持久代)的容量 (字节) |
|
YGC |
从应用程序启动到采样时年轻代中gc次数 |
|
FGC |
从应用程序启动到采样时old代(全gc)gc次数 |
5、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) |
6、jstat -gcnew <pid>:年轻代对象的信息。
|
显示列名 |
具体描述 |
|
S0C |
年轻代中第一个survivor(幸存区)的容量 (字节) |
|
S1C |
年轻代中第二个survivor(幸存区)的容量 (字节) |
|
S0U |
年轻代中第一个survivor(幸存区)目前已使用空间 (字节) |
|
S1U |
年轻代中第二个survivor(幸存区)目前已使用空间 (字节) |
|
TT |
持有次数限制 |
|
MTT |
最大持有次数限制 |
|
EC |
年轻代中Eden(伊甸园)的容量 (字节) |
|
EU |
年轻代中Eden(伊甸园)目前已使用空间 (字节) |
|
YGC |
从应用程序启动到采样时年轻代中gc次数 |
|
YGCT |
从应用程序启动到采样时年轻代中gc所用时间(s) |
7、jstat -gcnewcapacity<pid>: 年轻代对象的信息及其占用量。
|
显示列名 |
具体描述 |
|
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、jstat -gcold <pid>:old代对象的信息。
|
显示列名 |
具体描述 |
|
PC |
Perm(持久代)的容量 (字节) |
|
PU |
Perm(持久代)目前已使用空间 (字节) |
|
OC |
Old代的容量 (字节) |
|
OU |
Old代目前已使用空间 (字节) |
|
YGC |
从应用程序启动到采样时年轻代中gc次数 |
|
FGC |
从应用程序启动到采样时old代(全gc)gc次数 |
|
FGCT |
从应用程序启动到采样时old代(全gc)gc所用时间(s) |
|
GCT |
从应用程序启动到采样时gc用的总时间(s) |
9、stat -gcoldcapacity <pid>: old代对象的信息及其占用量。
|
显示列名 |
具体描述 |
|
OGCMN |
old代中初始化(最小)的大小 (字节) |
|
OGCMX |
old代的最大容量(字节) |
|
OGC |
old代当前新生成的容量 (字节) |
|
OC |
Old代的容量 (字节) |
|
YGC |
从应用程序启动到采样时年轻代中gc次数 |
|
FGC |
从应用程序启动到采样时old代(全gc)gc次数 |
|
FGCT |
从应用程序启动到采样时old代(全gc)gc所用时间(s) |
|
GCT |
从应用程序启动到采样时gc用的总时间(s) |
10、jstat -gcpermcapacity<pid>: perm对象的信息及其占用量。
|
显示列名 |
具体描述 |
|
PGCMN |
perm代中初始化(最小)的大小 (字节) |
|
PGCMX |
perm代的最大容量 (字节) |
|
PGC |
perm代当前新生成的容量 (字节) |
|
PC |
Perm(持久代)的容量 (字节) |
|
YGC |
从应用程序启动到采样时年轻代中gc次数 |
|
FGC |
从应用程序启动到采样时old代(全gc)gc次数 |
|
FGCT |
从应用程序启动到采样时old代(全gc)gc所用时间(s) |
|
GCT |
从应用程序启动到采样时gc用的总时间(s) |
11、jstat -printcompilation <pid>:当前VM执行的信息。
|
显示列名 |
具体描述 |
|
Compiled |
编译任务的数目 |
|
Size |
方法生成的字节码的大小 |
|
Type |
编译类型 |
|
Method |
类名和方法名用来标识编译的方法。类名使用/做为一个命名空间分隔符。方法名是给定类中的方法。上述格式是由-XX:+PrintComplation选项进行设置的 |
参考文献:
http://docs.oracle.com/javase/1.5.0/docs/tooldocs/share/jstat.html#class_option
http://nassir.iteye.com/blog/1517484
【JVM命令系列】jstat的更多相关文章
- 【JVM命令系列】jstack
jstack用于打印出给定的java进程ID或core file或远程调试服务的Java堆栈信息,如果是在64位机器上,需要指定选项"-J-d64",Windows的jstack使 ...
- 【JVM命令系列】javap
命令基本概述 javap是JDK自带的反汇编器,可以查看java编译器为我们生成的字节码.通过它,可以对照源代码和字节码,从而了解很多编译器内部的工作.可以在命令行窗口先用javap -help看下j ...
- 【JVM命令系列】jmap
命令基本概述 Jmap是一个可以输出所有内存中对象的工具,甚至可以将VM 中的heap,以二进制输出成文本.打印出某个java进程(使用pid)内存内的,所有'对象'的情况(如:产生那些对象,及其数量 ...
- JVM基础系列第15讲:JDK性能监控命令
查看虚拟机进程:jps 命令 jps 命令可以列出所有的 Java 进程.如果 jps 不加任何参数,可以列出 Java 程序的进程 ID 以及 Main 函数短名称,如下所示. $ jps 6540 ...
- JVM 调优 - jstat
Java命令学习系列(四)——jstat 2015-07-31 分类:Java 阅读(11041) 评论(1) 阿里大牛珍藏架构资料,点击链接免费获取 jstat(JVM Statistics Mon ...
- JVM故障分析系列之四:jstack生成的Thread Dump日志线程状态
JVM故障分析系列之四:jstack生成的Thread Dump日志线程状态 2017年10月25日 Jet Ma JavaPlatform JVM故障分析系列系列文章 JVM故障分析系列之一: ...
- JVM基础系列第14讲:JVM参数之GC日志配置
说到 Java 虚拟机,不得不提的就是 Java 虚拟机的 GC(Garbage Collection)日志.而对于 GC 日志,我们不仅要学会看懂,而且要学会如何设置对应的 GC 日志参数.今天就让 ...
- JVM基础系列第13讲:JVM参数之追踪类信息
我们都知道 JVM 在启动的时候会去加载类信息,那么我们怎么得知他加载了哪些类,又卸载了哪些类呢?我们这一节就来介绍四个 JVM 参数,使用它们我们就可以清晰地知道 JVM 的类加载信息. 为了方便演 ...
- JVM基础系列第11讲:JVM参数之堆栈空间配置
JVM 中最重要的一部分就是堆空间了,基本上大多数的线上 JVM 问题都是因为堆空间造成的 OutOfMemoryError.因此掌握 JVM 关于堆空间的参数配置对于排查线上问题非常重要. tips ...
随机推荐
- 【Vue】Vue中的父子组件通讯以及使用sync同步父子组件数据
前言: 之前写过一篇文章<在不同场景下Vue组件间的数据交流>,但现在来看,其中关于“父子组件通信”的介绍仍有诸多缺漏或者不当之处, 正好这几天学习了关于用sync修饰符做父子组件数据双向 ...
- 官方问答--微信小程序常见FAQ (17.8.21-17.8.27)
给提问的开发者的建议:提问之前先查询 文档.通过社区右上角搜索搜索已经存在的问题. 写一个简明扼要的标题,并且正文描述清楚你的问题. 提交 BUG:需要带上基础库版本号,设备信息(iOS, Andro ...
- nvm版本控制以及node.js
nvm node.js版本控制工具 下载 nvm 包 地址:https://github.com/coreybutler/nvm-windows/releases 我们选择第一个:nvm-noinst ...
- mysql的索引问题分析
p.p1 { margin: 0.0px 0.0px 0.0px 0.0px; font: 12.0px "PingFang SC"; color: #454545 } span. ...
- REST:JAX-RS 与 Spring
原文:https://developer.okta.com/blog/2017/08/09/jax-rs-vs-spring-rest-endpoints 作者:Brian Demers 译者:htt ...
- 有var和没有var的本质区别
我们创建一个变量: var a = 100: 同时,大家也知道,就是不写var关键字也可以创建.在很多教程和说法中,将没有var 的这个名称称之为“全局变量”.如果我在全局直接写一个var abc = ...
- .Netcore之日志组件Log4net、Nlog性能比较
转载请注明出处http://www.cnblogs.com/supernebula/p/7506993.html .Netcore之Log4net.Nlog性能比较 最近在写一个开源.netcore ...
- python爬虫scrapy框架——人工识别知乎登录知乎倒立文字验证码和数字英文验证码
目前知乎使用了点击图中倒立文字的验证码: 用户需要点击图中倒立的文字才能登录. 这个给爬虫带来了一定难度,但并非无法解决,经过一天的耐心查询,终于可以人工识别验证码并达到登录成功状态,下文将和大家一一 ...
- PowerShell: 问题,此系统上禁止运行脚本解决方法
刚学Django,在PowerShell上建立一个虚拟环境,准备激活,问题来了: 激活的时候报错了,有点儿懵,之前在命令行没问题啊,我又去命令行试了下,果然可以: 感受到了暴击,赶紧上网求助大神 ...
- JQuery实用技巧--学会你也是大神(1)——插件的制作技巧
前 言 JRedu 学习之前,首先我们需要知道什么是JQuery? JQuery是一个优秀的javascript框架. JQuery是继Prototype之后又一个优秀的Javascript框架 ...