DK内置工具使用
- jps(Java Virtual Machine Process Status Tool)
查看所有的jvm进程,包括进程ID,进程启动的路径等等。
- jstack(Java Stack Trace)
① 观察jvm中当前所有线程的运行情况和线程当前状态。 ② 系统崩溃了?如果java程序崩溃生成core文件,jstack工具可以用来获得core文件的java stack和native stack的信息,从而可以轻松地知道java程序是如何崩溃和在程序何处发生问题。 ③ 系统hung住了?jstack工具还可以附属到正在运行的java程序中,看到当时运行的java程序的java stack和native stack的信息, 如果现在运行的java程序呈现hung的状态,jstack是非常有用的。
- jstat(Java Virtual Machine Statistics Monitoring Tool)
① jstat利用JVM内建的指令对Java应用程序的资源和性能进行实时的命令行的监控,包括了对进程的classloader,compiler,gc情况; ②监视VM内存内的各种堆和非堆的大小及其内存使用量,以及加载类的数量。
- jmap(Java Memory Map)
监视进程运行中的jvm物理内存的占用情况,该进程内存内,所有对象的情况,例如产生了哪些对象,对象数量;
- jinfo(Java Configuration Info)
观察进程运行环境参数,包括Java System属性和JVM命令行参数
具体命令使用:
- jstat
generalOption outputOptions 03 | -compiler:统计HotSpot Just- in -Time编译器的行为 |
05 | -gccapacity:统计新生区,老年区,permanent区的heap容量情况 |
06 | -gccause:统计最后一次gc和当前gc的原因 |
08 | -gcnewcapacity:统计新生代大小和空间 |
10 | -gcoldcapacity:统计老年代大小 |
11 | -gcpermcapacity:统计永久代大小 |
13 | -printcompilation:HotSpot编译方法统计 |
-class: 02 | jstat -class 17970 1000 10 |
03 | ########################################## |
04 | [root@lq225 conf] # jstat -class 2058 1000 10 |
05 | Loaded Bytes Unloaded Bytes Time |
06 | 1697 3349.5 0 0.0 1.79 |
07 | 1697 3349.5 0 0.0 1.79 |
08 | 1697 3349.5 0 0.0 1.79 |
09 | 1697 3349.5 0 0.0 1.79 |
10 | ................................................... |
11 | ######################## 术语分隔符 ######################## |
-compiler 01 | Compiled Failed Invalid Time FailedType FailedMethod |
03 | ..................................................... |
04 | ######################## 术语分隔符 ######################## |
09 | #FailedType 最后一次编译错误的类型 |
10 | #FailedMethod 最后一次编译错误的类名和方法 |
-gc: 02 | jstat -gc 2058 2000 20 |
03 | ############################## |
04 | S0C S1C S0U S1U EC EU OC OU PC PU YGC YGCT FGC FGCT GCT |
05 | 8704.0 8704.0 805.5 0.0 69952.0 64174.5 174784.0 2644.5 16384.0 10426.7 2 0.034 0 0.000 0.034 |
06 | 8704.0 8704.0 805.5 0.0 69952.0 64174.5 174784.0 2644.5 16384.0 10426.7 2 0.034 0 0.000 0.034 |
07 | 8704.0 8704.0 805.5 0.0 69952.0 64174.5 174784.0 2644.5 16384.0 10426.7 2 0.034 0 0.000 0.034 |
08 | ............................................. |
09 | ######################## 术语分隔符 ######################## |
-gccapacity 01 | NGCMN NGCMX NGC S0C S1C EC OGCMN OGCMX OGC OC PGCMN PGCMX PGC PC YGC FGC |
02 | 131072.0 131072.0 131072.0 13056.0 13056.0 104960.0 393216.0 393216.0 393216.0 393216.0 65536.0 65536.0 65536.0 65536.0 1 0 |
03 | .......................................................................................................... |
04 | ######################## 术语分隔符 ######################## |
13 | #OC 当前老年代?Current old space capacity (KB). |
17 | #PC 当前永久区?Current Permanent space capacity (KB). |
-gccause 01 | S0 S1 E O P YGC YGCT FGC FGCT GCT LGCC GCC |
02 | 0.00 99.84 12.76 0.92 46.23 1 0.016 0 0.000 0.016 unknown GCCause No GC |
03 | ................................................ |
04 | ######################## 术语分隔符 ######################## |
05 | #S0 年轻代中第一个survivor(幸存区)已使用的占当前容量百分比 |
06 | #S1 年轻代中第二个survivor(幸存区)已使用的占当前容量百分比 |
07 | #E 年轻代中Eden(伊甸园)已使用的占当前容量百分比 |
10 | #YGC 从应用程序启动到采样时年轻代中gc次数 |
11 | #FGC 从应用程序启动到采样时old代(全gc)gc次数 |
12 | #FGCT 从应用程序启动到采样时old代(全gc)gc所用时间(s) |
13 | #GCT 从应用程序启动到采样时gc用的总时间(s) |
例如 -gcutil : 2 | jstat -gcutil 2058 1000 10 |
3 | ################################ |
4 | [root@lq225 conf] # jstat -gcutil 2058 1000 10 |
5 | S0 S1 E O P YGC YGCT FGC FGCT GCT |
6 | 9.25 0.00 96.73 1.51 63.64 2 0.034 0 0.000 0.034 |
7 | 9.25 0.00 96.73 1.51 63.64 2 0.034 0 0.000 0.034 |
8 | 9.25 0.00 96.73 1.51 63.64 2 0.034 0 0.000 0.034 |
9 | 9.25 0.00 96.73 1.51 63.64 2 0.034 0 0.000 0.034 |
- jmap
02 | -dump:[live,] format =b, file =<filename> 使用hprof二进制形式,输出jvm的heap内容到文件=. live子选项是可选的,假如指定live选项,那么只输出活的对象到文件. |
03 | -finalizerinfo 打印正等候回收的对象的信息. |
04 | -heap 打印heap的概要信息,GC使用的算法,heap的配置及wise heap的使用情况. |
05 | -histo[:live] 打印每个class的实例数目,内存占用,类全名信息. VM的内部类名字开头会加上前缀”*”. 如果live子参数加上后,只统计活的对象数量. |
06 | -permstat 打印classload和jvm heap长久层的信息. 包含每个classloader的名字,活泼性,地址,父classloader和加载的class数量. 另外,内部String的数量和占用内存数也会打印出来. |
07 | -F 强迫.在pid没有相应的时候使用-dump或者-histo参数. 在这个模式下,live子参数无效. |
10 | pid 需要被打印配相信息的java进程 id . |
例如 -histo : 2 | ############################ |
3 | num #instances #bytes class name |
4 | ---------------------------------------------- |
6 | 2: 19621 2791880 <constMethodKlass> |
7 | 3: 19621 2520048 <methodKlass> |
9 | ............................................................ |
例如 -dump: 01 | #生成的文件可以使用jhat工具进行分析,在OOM(内存溢出)时,分析大对象,非常有用 |
02 | jmap -dump:live, format =b, file =data.hprof 2058 |
04 | #通过使用如下参数启动JVM,也可以获取到dump文件: |
05 | -XX:+HeapDumpOnOutOfMemoryError |
06 | -XX:HeapDumpPath=./java_pid<pid>.hprof |
08 | #如果在虚拟机中导出的heap信息文件可以拿到WINDOWS上进行分析,可以查找诸如内存方面的问题,可以这么做: |
10 | #执行成功后,访问http://localhost:7000即可查看内存信息。(首先把7000端口打开) |
- jinfo
04 | Attaching to process ID 2058, please wait... |
05 | Debugger attached successfully. |
06 | Server compiler detected. |
07 | JVM version is 24.0-b56 |
08 | Java System Properties: |
10 | java.runtime.name = Java(TM) SE Runtime Environment |
11 | project.name = Amoeba-MySQL |
12 | java.vm.version = 24.0-b56 |
13 | sun.boot.library.path = /usr/ local /java/jdk1.7/jre/lib/amd64 |
14 | ................................................ |
16 | #<span></span> 查看2058的MaxPerm大小可以用 |
17 | jinfo -flag MaxPermSize 2058 |
18 | ############################ |
19 | -XX:MaxPermSize=100663296 |
- jps
5 | 3370 Jps <span></span>2058 xxxxxxxxx<span></span> |
一些术语的中文解释 01 | S0C:年轻代中第一个survivor(幸存区)的容量 (字节) |
02 | S1C:年轻代中第二个survivor(幸存区)的容量 (字节) |
03 | S0U:年轻代中第一个survivor(幸存区)目前已使用空间 (字节) |
04 | S1U:年轻代中第二个survivor(幸存区)目前已使用空间 (字节) |
05 | EC:年轻代中Eden(伊甸园)的容量 (字节) |
06 | EU:年轻代中Eden(伊甸园)目前已使用空间 (字节) |
10 | PU:Perm(持久代)目前已使用空间 (字节) |
11 | YGC:从应用程序启动到采样时年轻代中gc次数 |
12 | YGCT:从应用程序启动到采样时年轻代中gc所用时间(s) |
13 | FGC:从应用程序启动到采样时old代(全gc)gc次数 |
14 | FGCT:从应用程序启动到采样时old代(全gc)gc所用时间(s) |
15 | GCT:从应用程序启动到采样时gc用的总时间(s) |
16 | NGCMN:年轻代(young)中初始化(最小)的大小 (字节) |
17 | NGCMX:年轻代(young)的最大容量 (字节) |
18 | NGC:年轻代(young)中当前的容量 (字节) |
19 | OGCMN:old代中初始化(最小)的大小 (字节) |
22 | PGCMN:perm代中初始化(最小)的大小 (字节) |
25 | S0:年轻代中第一个survivor(幸存区)已使用的占当前容量百分比 |
26 | S1:年轻代中第二个survivor(幸存区)已使用的占当前容量百分比 |
27 | E:年轻代中Eden(伊甸园)已使用的占当前容量百分比 |
30 | S0CMX:年轻代中第一个survivor(幸存区)的最大容量 (字节) |
31 | S1CMX:年轻代中第二个survivor(幸存区)的最大容量 (字节) |
32 | ECMX:年轻代中Eden(伊甸园)的最大容量 (字节) |
33 | DSS:当前需要survivor(幸存区)的容量 (字节)(Eden区已满) |
使用visualvm监控tomcat
- 修改catalina.sh,添加下面一行:
1 | CATALINA_OPTS= "$CATALINA_OPTS -Dcom.sun.management.jmxremote=true -Djava.rmi.server.hostname=192.168.55.255 -Dcom.sun.management.jmxremote.port=8086 -Dcom.sun.management.jmxremote.ssl=false -Dcom.sun.management.jmxremote.authenticate=false" |
4 | #1、用hostname -i 查看是否为127.0.01,如果是,则必须配置-Djava.rmi.server.hostname为本机IP。 |
5 | #2、检查防火墙(iptables)是否开启,以及是否开放jmxremote.port所指定的端口。 |
|