• jvm工具


    jvm工具

    知识,经验是基础,数据是依据,工具是运营知识处理数据的手段

    数据:运行日志、异常堆栈、GC日志、线程快照、堆转存储快照

    JPS:虚拟机进程状况工具

    jvm process status tool

    (Local Virtual Machine Identifier)LVMID和名称。

    -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

    jstat:虚拟机统计信息监视工具

    运行期定位虚拟机性能问题首选工具

    jstat -gc pid 

    可以显示gc的信息,gc次数,及时间。

    S0C、S1C、S0U、S1U :幸存区使用情况(总容量,已使用容量) 

    EC、EU:Eden使用情况。

    OC、OU:年老代使用情况。

    PC、PU:持久代使用情况。

    YGC、YGCT 、FGC、FGCT、GCT:GC次数和时间。

    jstat -gccapacity 22044 250 3

    可以显示,VM内存中三代(young,old,perm)对象的使用和占用大小。

    NGCMN、NGCMX、NGC:年轻代大小(初始化、最大、当前使用)
    S0C、S1C、EC:年轻代大小(幸存者、Eden)
    OGCMN、OGCMX、OGC、OC:年老代大小(初始化、最大、当前使用、容量)
    PGCMN、PGCMX、PGC、PC:持久代大小(初始化、最大、当前使用、容量)
    YGC、FGC:GC次数

    jstat -gcutil 22044 250 3

    统计gc信息统计

    S0,S1,E,O,P:已使用占当前容量百分比。

    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)
    NGCMN:年轻代(young)中初始化(最小)的大小 (字节)
    NGCMX:年轻代(young)的最大容量 (字节)
    NGC:年轻代(young)中当前的容量 (字节)
    OGCMN:old代中初始化(最小)的大小 (字节)
    OGCMX:old代的最大容量 (字节)
    OGC:old代当前新生成的容量 (字节)
    PGCMN:perm代中初始化(最小)的大小 (字节)
    PGCMX:perm代的最大容量 (字节)
    PGC:perm代当前新生成的容量 (字节)
    S0:年轻代中第一个survivor(幸存区)已使用的占当前容量百分比
    S1:年轻代中第二个survivor(幸存区)已使用的占当前容量百分比
    E:年轻代中Eden(伊甸园)已使用的占当前容量百分比
    O:old代已使用的占当前容量百分比
    P:perm代已使用的占当前容量百分比
    S0CMX:年轻代中第一个survivor(幸存区)的最大容量 (字节)
    S1CMX :年轻代中第二个survivor(幸存区)的最大容量 (字节)
    ECMX:年轻代中Eden(伊甸园)的最大容量 (字节)
    DSS:当前需要survivor(幸存区)的容量 (字节)(Eden区已满)
    TT: 持有次数限制
    MTT : 最大持有次数限制

    参考:

    http://nassir.iteye.com/blog/1517484

    http://blog.csdn.net/zhaozheng7758/article/details/8623549

    jinfo:Java配置信息工具

    实时参考和调整虚拟机各项参数

    参考:http://blog.csdn.net/gtuu0123/article/details/6056758

    jmap:Java内存映像工具

    -dump:[live,]format=b,file=<filename> 使用hprof二进制形式,输出jvm的heap内容到文件=. live子选项是可选的,假如指定live选项,那么只输出活的对象到文件. 

    -finalizerinfo 打印正等候回收的对象的信息.

    -heap 打印heap的概要信息,GC使用的算法,heap的配置及wise heap的使用情况.

    -histo[:live] 打印每个class的实例数目,内存占用,类全名信息. VM的内部类名字开头会加上前缀”*”. 如果live子参数加上后,只统计活的对象数量. 

    -permstat 打印classload和jvm heap长久层的信息. 包含每个classloader的名字,活泼性,地址,父classloader和加载的class数量. 另外,内部String的数量和占用内存数也会打印出来. 

    -F 强迫.在pid没有相应的时候使用-dump或者-histo参数. 在这个模式下,live子参数无效. 

    -h | -help 打印辅助信息 

    -J 传递参数给jmap启动的jvm. 

    jmap -J-d64 -histo 22044 >/usr/local/22044_histo.log

    jmap -dump:format=b,file=/usr/local/22044_dump.log 22044

    jmap -J-d64 -heap 22044

    jmap -J-d64 -permstat 22044

    参考:http://blog.csdn.net/fenglibing/article/details/6411953

    jhat:虚拟机堆转储快照分析工具

    与jmap搭配使用,分析jmap生成的堆转储快照。

    参考:http://blog.csdn.net/gtuu0123/article/details/6039474

    jstack:Java堆栈跟踪工具

    生成虚拟机当前时刻的线程快照,一般称为threaddump或javacore文件。

    -F当’jstack [-l] pid’没有相应的时候强制打印栈信息

    -l长列表. 打印关于锁的附加信息,例如属于java.util.concurrent的ownable synchronizers列表.

    -m打印java和native c/c++框架的所有栈信息.

    -h | -help打印帮助信息

    参考:

    http://jameswxx.iteye.com/blog/1041173

    http://jingyan.baidu.com/article/4f34706e3ec075e387b56df2.html

    HSDIS:JIT代码反编译

    参考:http://www.infoq.com/cn/articles/zzm-java-hsdis-jvm

    JConsole:Java监视与管理控制台

    参考:http://jiajun.iteye.com/blog/810150

    Visual:多合一故障处理工具

    不需要被监视的程序基于特殊的Agent运行,可直接应用在生产环境

    远程监控tomcat

    1、服务器没有安装screen,需要先安装screen

    安装screen:http://www.cnblogs.com/mchina/archive/2013/01/30/2880680.html

    2、通过 hostname -i 检测服务器本机ip

    3、在服务器启动jstatd 

    http://ihuangweiwei.iteye.com/blog/1219302

  • 相关阅读:
    人月神话--没有银弹软件工程中的根本和次要问题(No Silver Bullet Essence and Accident in Software Engineering)
    人与人之间最难得是合作,组件与组件之间最难得时协作。
    关注软件构架与软件构架师
    软件产品本质是逻辑或者说事概念产品
    为什么需求分析离不开系统逻辑模型
    MySQL中varchar最大长度是多少?【转】
    WCF自定义授权[转自小庄的博客]
    PetShop的系统架构设计[转]
    百练 2734 十进制到八进制 解题报告
    百练 2818 密码
  • 原文地址:https://www.cnblogs.com/tenghoo/p/jvm_tool.html
Copyright © 2020-2023  润新知