java使用jdk自带jvm工具

jvm小工具:

1.用 jps(JVM process Status)可以查看虚拟机启动的所有进程、执行主类的全名、JVM启动参数,比如当执行了JPSTest类中的main方法后(main方法持续执行),执行 jps -l可看到下面的JPSTest类的pid为31354,加上-v参数还可以看到JVM启动参数。

          -q:仅输出VM标识符,不包括classname,jar name,arguments in main method

          -m:输出main method的参数 ​

          -l:输出完全的包名,应用主类名,jar的完全路径名 ​

          -v:输出jvm参数 ​

          -V:输出通过flag文件传递到JVM中的参数(.hotspotrc文件或-XX:Flags=所指定 的文件 ​

          -Joption:传递参数到vm,例如:-J-Xms512m

2.用jstat(JVM Statistics Monitoring Tool)监视虚拟机信息 jstat -gc -t 11656 500 10 :每500毫秒打印一次Java堆状况(各个区的容量、使用容量、gc时间等信息),打印10次

        -gc :将显示与垃圾收集相关的统计信息

                  自JVM启动以来的-t时间戳将被打印

          11656:目标JVM进程ID

         500 :**每500 毫秒将打印一次统计信息。

        10:将打印10次迭代的统计信息。 因此,以上选项将导致JVM打印指标5000(即500x 10次迭代)

   详情:

       S0C:年轻代中第一个survivor(幸存区)的容量 (kb)

      S1C:年轻代中第二个survivor(幸存区)的容量 (kb)

      S0U:年轻代中第一个survivor(幸存区)目前已使用空间 (kb)

     S1U:年轻代中第二个survivor(幸存区)目前已使用空间 (kb)

     EC:年轻代中Eden(伊甸园)的容量 (kb)

     EU:年轻代中Eden(伊甸园)目前已使用空间 (kb)

     OC:Old代的容量 (kb)

     OU:Old代目前已使用空间 (kb)

     PC:Perm(持久代)的容量 (kb)

     PU:Perm(持久代)目前已使用空间 (kb)

     YGC:从应用程序启动到采样时年轻代中gc次数

     YGCT:从应用程序启动到采样时年轻代中gc所用时间(s)

     FGC:从应用程序启动到采样时old代(全gc)gc次数

     FGCT:从应用程序启动到采样时old代(全gc)gc所用时间(s)

     GCT:从应用程序启动到采样时gc用的总时间(s)

     NGCMN:年轻代(young)中初始化(最小)的大小 (kb)

     NGCMX:年轻代(young)的最大容量 (kb)

     NGC:年轻代(young)中当前的容量 (kb)

    OGCMN:old代中初始化(最小)的大小 (kb)

    OGCMX:old代的最大容量 (kb)

    OGC:old代当前新生成的容量 (kb)

    PGCMN:perm代中初始化(最小)的大小 (kb)

    PGCMX:perm代的最大容量 (kb)

    PGC:perm代当前新生成的容量 (kb)

    S0:年轻代中第一个survivor(幸存区)已使用的占当前容量百分比

    S1:年轻代中第二个survivor(幸存区)已使用的占当前容量百分比

    E:年轻代中Eden(伊甸园)已使用的占当前容量百分比

    O:old代已使用的占当前容量百分比

    P:perm代已使用的占当前容量百分比

    S0CMX:年轻代中第一个survivor(幸存区)的最大容量 (kb)

    S1CMX :年轻代中第二个survivor(幸存区)的最大容量 (kb)

   ECMX:年轻代中Eden(伊甸园)的最大容量 (kb)

   DSS:当前需要survivor(幸存区)的容量 (kb)(Eden区已满)

   TT: 持有次数限制

   MTT : 最大持有次数限制

3.用jmap(Memory Map for Java)查看堆内存信息 执行jmap -histo pid可以打印出当前堆中所有每个类的实例数量和内存占用,如下,class name是每个类的类名([B是byte类型,[C是char类型,[I是int类型),bytes是这个类的所有示例占用内存大小,instances是这个类的实例数量:

4.jvisualvm:自带好用的jvm查看工具   需安装一个插件   在工具中---》插件中查找也可自行搜索下载  Visual GC插件

 

    

5.VisualVM:多合一故障管理工具(需下载下来)(这款没用过)

这个工具也很牛bility。它同jconsole都是一个基于图形化界面的、可以查看本地及远程的JAVA GUI监控工具,Jvisualvm同jconsole的使用方式一样,直接在命令行打入jvisualvm即可启动,jvisualvm界面更美观一些,数据更实时:

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值