JSTAT命令-对Java应用程序的资源和性能进行实时的监控

createh52周前 (12-16)技术教程11

对于监控JVM,jdk也提供了很多工具,供我们来使用,其中命令jstat,是JDK自带的一个轻量级小工具,可以查看堆内存各部分的使用量,以及加载类的数量,对Java应用程序的资源和性能进行实时的监控,包括了对Heap size和垃圾回收状况的监控。命令行输入jstat可以查看这个命令的用法。


用法格式为:jstat -<option> [-t] [-h<lines>] <vmid> [<interval> [<count>]]

  • option: 参数选项
  • -t: 可以在打印的列加上Timestamp列,用于显示系统运行的时间
  • -h: 可以在周期性数据数据的时候,可以在指定输出多少行以后输出一次表头
  • vmid: Virtual Machine ID( 进程的 pid)
  • interval: 执行每次的间隔时间,单位为毫秒
  • count: 用于指定输出多少次记录,缺省则会一直打印
  • 输入jstat -options可以查看参数选择:


    各个参数含义如下:

  • -class 显示ClassLoad的相关信息;
  • -compiler 显示JIT编译的相关信息;
  • -gc 显示和gc相关的堆信息;
  • -gccapacity    显示各个代的容量以及使用情况;
  • -gccause 显示垃圾回收的相关信息(通-gcutil),同时显示最后一次或当前正在发生的垃圾回收的诱因;
  • -gcmetacapacity 显示metaspace的大小
  • -gcnew 显示新生代信息;
  • -gcnewcapacity 显示新生代大小和使用情况;
  • -gcold 显示老年代和永久代的信息;
  • -gcoldcapacity 显示老年代的大小;
  • -gcutil   显示垃圾收集信息;
  • -printcompilation 输出JIT编译的方法信息;
  • 下面通过实例来看一下jstat -options各个参数,首先要用jps工具找出一个Java程序对于的PID:



    参数-class :


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

    参数-compiler:


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

    参数-gc:


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

    参数-gccapacity:


    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次数

    参数-gccause:


    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)
    LGCC:最后一次GC原因
    GCC:当前GC原因(No GC 为当前没有执行GC)

    参数-gcmetacapacity:


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

    参数 -gcnew:


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

    参数-gcnewcapacity:


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

    参数-gcold:


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

    参数-gcoldcapacity:


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

    参数-gcutil:


    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)

    参数-printcompilation:


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

    对于用法格式为:jstat -<option> [-t] [-h<lines>] <vmid> [<interval> [<count>]],我们知道了-options的用法,和vmid: Virtual Machine ID( 进程的 pid),下面加上时间戳-t选项,和interval指定时间为1s:


    如果没有指定count,则会一直打印下去,下面我们指定5次来演示一下:


    这样在第5次打印完毕,就会停止打印!


    相关文章

    从Java转储分析来改进Java应用程序的性能(上)

    1 引言垃圾回收(Garbage Collection,GC)在Java的内存管理中扮演着至关重要的角色。它负责自动回收不再被使用的内存资源,从而避免内存泄漏。垃圾回收器通过一组专门的线程来执行内存回...

    这样做优化,实现 0.059s 启动一个SpringBoot项目

    前言最近自己用Spring Cloud Alibaba做了一个微服务架构的项目,部署的时候遇到了难题:内存不够。目前该项目有7个微服务,因为我只有一台阿里云的服务器(2C 4G),所以我只能把所有的微...

    JDK 8中JAVAFX的终结:保持应用程序存活

    虽然建议您将应用程序更新到较新的 Java 版本,但其他 OpenJDK 发行版可以使您的系统在 Java 8 上运行 JavaFX。译自 End of the Road for JavaFX in...

    java程序、小程序和应用程序三者为什么可以共同存在

    今天跟大家总结一下java程序、小程序和应用程序三者之间的应用关系,如果你有更好的想法,可以写在评论区。一个程序中可以有多个类,但只能有一个类是主类。在Java应用程序中,这个主类是指包含main()...

    应用程序被java安全阻止的解决办法

    internet选项是灰色的,运行输入Iexplore -extoff可解。然后控制面板-程序找到java,然后点开点安全,例外网站输入,必须加http,然后就可以了。...