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

 

posted @ 2017-01-12 09:13  青羽  阅读(1177)  评论(0编辑  收藏  举报