zoukankan      html  css  js  c++  java
  • jstat命令 -- Java虚拟机监控统计工具

    http://blog.sina.com.cn/s/blog_5f5716580100u76r.html


    语法:
    jstat [generalOption | outputOptions vmid [interval[s|ms] [count]]]

    选项:
    1.generalOption
    -help 帮助
    -options 打印选项

    2.outputOptions
    输出选项
    -h n 每n个样本,显示header一次
    -t n 在第一列显示时间戳列,时间戳时从jvm启动开始计算
    -Jjvmoption 传递jvm选项
    -statOption 决定统计什么信息
    (1)class:统计classloader的行为
    ColumnDescription
    Loaded 被读入类的数量
    Bytes 被读入的字节数(K)
    Unloaded 被卸载类的数量
    Bytes 被卸载的字节数(K)
    Time 花费在load和unload类的时间


    (2)compiler:统计hotspot just-in-time编译器的行为

    ColumnDescription
    Compiled 被执行的编译任务的数量
    Failed 失败的编译任务的数量
    Invalid 无效的编译任务的数量
    Time 花费在执行编译任务的时间.
    FailedType 最近失败编译的编译类弄.
    FailedMethod 最近失败编译的类名和方法名


    (3)gc:统计gc行为

    ColumnDescription
    S0C 当前S0的容量 (KB).
    S1C 当前S1的容量 (KB).
    S0U S0的使用 (KB).
    S1U S1的使用 (KB).
    EC 当前eden的容量(KB).
    EU eden的使用 (KB).
    OC 当前old的容量(KB).
    OU old的使用 (KB).
    PC 当前perm的容量 (KB).
    PU perm的使用 (KB).
    YGC young代gc的次数
    YGCT young代gc花费的时间
    FGC full gc的次数
    FGCT full gc的时间
    GCT 垃圾收集收集的总时间


    (4)gccapacity:统计堆中代的容量、空间

    ColumnDescription
    NGCMN 年轻代的最小容量 (KB).
    NGCMX 年轻代的最大容量 (KB).
    NGC 当前年轻代的容量 (KB).
    S0C 当前S0的空间 (KB).
    S1C 当前S1的空间 (KB).
    EC 当前eden的空间 (KB).
    OGCMN 年老代的最小容量 (KB).
    OGCMX 年老代的最大容量 (KB).
    OGC 当前年老代的容量 (KB).
    OC 当前年老代的空间 (KB).
    PGCMN 永久代的最小容量 (KB).
    PGCMX 永久代的最大容量 (KB).
    PGC 当前永久代的容量 (KB).
    PC 当前永久代的空间 (KB).
    YGC 年轻代gc的次数
    FGC full gc的次数


    (5)gccause:垃圾收集统计,包括最近引用垃圾收集的事件,基本同gcutil,比gcutil多了两列

    ColumnDescription
    LGCC 最近垃圾回收的原因.
    GCC 当前垃圾回收的原因.


    (6)gcnew:统计新生代的行为

    ColumnDescription
    S0C 当前S0空间 (KB).
    S1C 当前S1空间 (KB).
    S0U S0空间使用 (KB).
    S1U S1空间使用 (KB).
    TT Tenuring threshold.
    MTT 最大的tenuring threshold.
    DSS 希望的Survivor大小 (KB).
    EC 当前eden空间 (KB).
    EU eden空间使用 (KB).
    YGC 年轻代gc次数
    YGCT 年轻代垃圾收集时间


    (7)gcnewcapacity:统计新生代的大小和空间

    ColumnDescription
    NGCMN           最小的年轻代的容量 (KB).
    NGCMX     最大的年轻代的容量 (KB).
    NGC     当前年轻代的容量 (KB).
    S0CMX 最大的S0空间 (KB).
    S0C 当前S0空间 (KB).
    S1CMX 最大的S1空间 (KB).
    S1C 当前S1空间 (KB).
    ECMX 最大eden空间 (KB).
    EC 当前eden空间 (KB).
    YGC 年轻代gc数量
    FGC full gc数量


    (8)gcold:统计旧生代的行为

    ColumnDescription
    PC 当前perm空间 (KB).
    PU perm空间使用 (KB).
    OC 当前old空间 (KB).
    OU old空间使用 (KB).
    YGC 年轻代gc次数
    FGC full gc次数
    FGCT full gc时间
    GCT 垃圾收集总时间


    (9)gcoldcapacity:统计旧生代的大小和空间

    ColumnDescription
    OGCMN 最小年老代容量 (KB).
    OGCMX 最大年老代容量 (KB).
    OGC 当前年老代容量 (KB).
    OC 当前年老代空间 (KB).
    YGC 年轻代gc次数
    FGC full gc次数
    FGCT full gc时间
    GCT 垃圾收集总时间


    (10)gcpermcapacity:统计永久代的大小和空间

    ColumnDescription
    PGCMN 永久代最小容量 (KB).
    PGCMX 永久代最大容量 (KB).
    PGC 当前永久代的容量 (KB).
    PC 当前永久代的空间 (KB).
    YGC 年轻代gc次数
    FGC full gc次数
    FGCT full gc时间
    GCT 垃圾收集总时间


    (11)gcutil:垃圾收集统计

    ColumnDescription
    S0 S0使用百分比
    S1 S1使用百分比
    E eden使用百分比
    O old使用百分比
    P perm使用百分比
    YGC 年轻代gc次数
    YGCT 年轻代gc时间
    FGC full gc次数
    FGCT full gc时间
    GCT 垃圾收集总时间


    (12)printcompilation:hotspot编译方法统计

    ColumnDescription
    Compiled 被执行的编译任务的数量.
    Size 方法字节码的字节数
    Type 编译类型
    Method 编译方法的类名和方法名。类名使用"/" 代替 "." 作为空间分隔符. 方法名是给出类的方法名. 格式是一致于HotSpot - XX:+PrintComplation 选项.
    3.vmid 虚拟机标识符,格式为:[protocol :][//]lvmid [@hostname [:port ]/servername ]
    4.interval 是显示间隔
    5.count 是显示次数

    举例:

    (1)每隔5秒显示在127.0.0.1机器上的18668jvm的classloader相关信息,一共显示100次,并且每5次显示一个列头,显示时间戳

    (2)每隔5秒显示在127.0.0.1机器上的18668jvm的gc统计相关信息,一共显示100次,并且每5次显示一个列头,显示时间戳


    使用jstat命令监测如下内存使用和垃圾回收统计数据:
      $ <JDK>/bin/jstat –gcutil  [-h<lines>] <pid> <interval>
    jstat - gcutil选项打印所运行应用程序进程ID <pid>在指定抽样间隔<interval>下,堆使用及垃圾回收时间摘要,并且每<lines>行显示一次头信息。这产生出以下样例输出:
      S0     S1     E      O      P     YGC   YGCT    FGC    FGCT     GCT
      0.00   0.00  24.48  46.60  90.24  142   0.530   104   28.739   29.269
      0.00   0.00   2.38  51.08  90.24  144   0.536   106   29.280   29.816
      0.00   0.00  36.52  51.08  90.24  144   0.536   106   29.280   29.816
      0.00  26.62  36.12  51.12  90.24  145   0.538   107   29.552   30.090
    名列含义:

    S0:Survivor space 0 utilization as a percentage of the space's current capacity.
    S1:Survivor space 1 utilization as a percentage of the space's current capacity.
    E:Eden space utilization as a percentage of the space's current capacity.
    O:Old space utilization as a percentage of the space's current capacity.
    P:Permanent space utilization as a percentage of the space's current capacity.
    YGC:Number of young generation GC events.
    YGCT:Young generation garbage collection time.
    FGC:Number of full GC events.
    FGCT:Full garbage collection time.
    GCT:Total garbage collection time.

  • 相关阅读:
    Java安全之对称加密、非对称加密、数字签名
    Java 设计模式 之 中介者模式(Mediator)
    使用jquery获取radio的值
    java6枚举类型
    java http头信息
    怎样用java生成GUID与UUID
    struts2国际化
    JSON.stringify(),JSON.parse(),toJSON()方法使用
    阻塞队列之六:LinkedBlockingDeque
    jQuery给控件赋值....
  • 原文地址:https://www.cnblogs.com/zengkefu/p/7441778.html
Copyright © 2011-2022 走看看