jdk性能监控&故障处理工具

前几篇文章为大家介绍了jvm调优的相关知识点,gc算法,垃圾回收器以及常见的jvm内存配置参数等内容。那么今天将和大家讲一下有关jdk自带的针对jvm调优的工具以及针对实战项目现场进行jvm内存优化!

jdk性能监控工具

方法调用

说到jvm的调优工具,可能很多的人都根本不知道是什么玩意!在这里我会和大家一一的介绍,帮助大家的理解和使用!


方法调用.png

看图可能大家会十分的迷茫,图中的明明都是在window下的可执行的.exe文件呀?为什么是方法调用呢?
这点大家可能真的不理解,在此给大家解释一下,图中也就是我们常用的所有的jvm调优以及监控工具,它们其实就是jdk自己自己写的一些有关底层的监控工具,只不过分模块打包成了不同的.exe可执行文件而已!


jdk监控工具源码.png

tools.jar 转文件类型.zip可以看出结果
tools解压.png

从图中解压可以看出,我们上面所说的所有的jvm调控工具都有相对应的源码,那么就可以很清晰的看出,这就是方法的调用!(这个不太重要,仅供大家理解,有兴趣可以查看源码解读)

jdk监控工具解析

jps

jps的话其实就是jvm虚拟机针对java的系统进程的一个查询,类似于linux系统中的ps -[option]+管道符过滤的功能,这个也是上述所说的监控工具中的入口,也就是最重要的一个,同时也是最简单的一个!(次处注意jps查看java进程的时候,同时jsp也是一个进程,并且jsp的pid也就是进程号一直在变动,所以你不能去分析jps的内存问题)


jps.png
jstat

jstat从字面意思就可以看出,是有关状态的意思,也就是监控此时jvm中某一个java进程的状态信息!一般情况下我们都会采用jstat -gc pid [间隔时间(单位ms)][打印多少次]去查看当前java进程的内存情况进行堆内存变化分析!具体参数如下:


jstat.png
-class (监视类装载、卸载数量、总空间以及耗费的时间)
 jstat -class 4513 
Loaded  加载class的数量
Bytes   class字节大小
Unloaded    未加载class的数量
Bytes   未加载class的字节大小
Time    加载时间
-compiler(输出JIT编译过的方法数量耗时等)
 jstat -compiler 4562 
Compiled    编译数量
Failed  编译失败数量
Invalid     无效数量
Time    编译耗时
FailedType  失败类型
FailedMethod    失败方法的全限定名
-gc(垃圾回收堆的行为统计,常用命令)
 jstat -gc 4562 
S0C survivor0区的总容量
S1C survivor1区的总容量
S0U survivor0区已使用的容量
S1C survivor1区已使用的容量
EC  Eden区的总容量
EU  Eden区已使用的容量
OC  Old区的总容量
OU  Old区已使用的容量
MC  方法区大小(JDK1.8)
MU  方法区使用大小(JDK1.8)
CCSC    压缩类空间大小
CCSU    压缩类空间使用大小
PC  当前perm的容量 (KB)(JDK1.7)
PU  perm的使用 (KB)(JDK1.7)
YGC     新生代垃圾回收次数
YGCT    新生代垃圾回收时间
FGC 老年代垃圾回收次数
FGCT    老年代垃圾回收时间
GCT 垃圾回收总消耗时间
-gccapacity(同-gc,还会输出Java堆各区域使用到的最大、最小空间)
 jstat -gccapacity 4562 
NGCMN   新生代占用的最小空间
NGCMX   新生代占用的最大空间
NGC 当前新生代的空间
OGCMN   老年代占用的最小空间
OGCMX   老年代占用的最大空间
OGC     当前年老代的容量 (KB)
OC      当前年老代的空间 (KB)
MCMN    最小元数据容量
MCMX    最大元数据容量
MC      当前元数据空间大小
CCSMN   最小压缩类空间大小
CCSMX   最大压缩类空间大小
CCSC    当前压缩类空间大小
PGCMN   perm占用的最小空间
PGCMX   perm占用的最大空间
PGC perm的空间 (KB)
YGC     年轻代GC次数
FGC     老年代GC次数
-gcutil(同-gc,输出的是已使用空间占总空间的百分比)
 jstat -gcutil 4562 
S0  幸存区S0当前使用比例
S1  幸存区S1当前使用比例
E   伊甸园区使用比例
O   老年代使用比例
M   元数据区使用比例
CCS 压缩使用比例
YGC 年轻代垃圾回收次数
YGCT    年轻代垃圾回收消耗时间
FGC 老年代垃圾回收次数
FGCT    老年代垃圾回收消耗时间
GCT 垃圾回收消耗总时间
-gcnew(统计新生代行为)
 jstat -gcnew 4562 
S0C 第一个幸存区大小
S1C 第二个幸存区的大小
S0U 第一个幸存区的使用大小
S1U 第二个幸存区的使用大小
TT  对象在新生代存活的次数Tenuring threshold(提升阈值)
MTT 对象在新生代存活的最大次数,最大的tenuring threshold
DSS 期望的幸存区大小,survivor区域大小 (KB)
EC  伊甸园区的大小
EU  伊甸园区的使用大小
YGC 年轻代垃圾回收次数
YGCT    年轻代垃圾回收消耗时间
-gcnewcapacity(新生代与其相应的内存空间的统计)
 jstat -gcnewcapacity 4562 
NGCMN   新生代最小容量
NGCMX   新生代最大容量
NGC 当前新生代容量 (KB)
S0CMX   最大幸存区S0大小 (KB)
S0C 当前幸存区S0空间 (KB)
S1CMX   最大幸存区S1大小
S1C 当前幸存区S1大小
ECMX    最大eden空间 (KB)
EC  当前eden空间 (KB)
OGCMX   老年代占用的最小空间
OGCMN   老年代占用的最大空间
OGC 当前年老代的容量 (KB)
OC  年老代的空间 (KB)
PGCMN   perm占用的最小空间
PGCMX   perm占用的最大空间
PGC perm空间 (KB)
YGC 年轻代垃圾回收次数
FGC 老年代回收次数
-gcold(统计老年代行为)
 jstat -gcold 4562 
PC  Perm大小
PU  Perm使用大小
MC  方法区大小
MU  方法区使用大小
CCSC    压缩类空间大小
CCSU    压缩类空间使用大小
OC  老年代大小
OU  老年代使用大小
YGC 年轻代垃圾回收次数
FGC 老年代垃圾回收次数
FGCT    老年代垃圾回收消耗时间
GCT 垃圾回收消耗总时间
-gcoldcapacity(老年代与其相应的内存空间的统计)
 jstat -gcoldcapacity 4562 
OGCMN   老年代最小容量
OGCMX   老年代最大容量
OGC 当前年老代的容量 (KB)
OC  当前年老代的空间 (KB)
YGC 年轻代垃圾回收次数
FGC 老年代垃圾回收次数
FGCT    老年代垃圾回收消耗时间
GCT 垃圾回收消耗总时间
-gcpermcapacity(永久代与其相应内存空间的统计)
 jstat -gcnewcapacity 4562 
MCMN    最小元数据容量
MCMX    最大元数据容量
MC  当前元数据空间大小
CCSMN   最小压缩类空间大小
CCSMX   最大压缩类空间大小
CCSC    当前压缩类空间大小
YGC 年轻代垃圾回收次数
FGC 老年代垃圾回收次数
FGCT    老年代垃圾回收消耗时间
GCT 垃圾回收消耗总时间
jinfo

jinfo主要是做jvm当前的java进程的实时参数调整等,这个没有过的解释,用法给大家总结如下:


jinfo.png
jmap

jmap是比较重要的一个工具,因为这个主要是用于当前jvm中的某个java进程的内存dump快照的工具,jamp通常用法就是生成当前的内存快照:
jmap -dump format=b,file="文件路径" pid。具体的用法总结如下:


jmap.png
jstack

jstack主要是分析堆栈的,这个工具也是比较重的,因为,很多的java代码中的线程死锁问题,死循环问题,都可以从这个工具中分析出来!具体用法如下:


jstack.png

OOM案例分析

制造一个oom异常场景
jvm内存配置参数:

-Xms10m -Xmx10m
package com.amazing.util;

import java.util.HashMap;
import java.util.Map;

/**
 * 测试oom异常检测
 */
public class OOMHeap {

    /**
     * oom异常引发原因
     */
    public static void testOom(){
        Map<String,Object> map = new HashMap<>();
        Object [] objetcs = new Object[500000];
        for (int i=0;i<500000;i++){
            map.put("key"+i,String.valueOf(i));
            objetcs[i] = i;
        }

    }

    public static void main(String[] args) {
        testOom();
    }

}

测试结果:


oom异常结果.png

此时,如果你的web应用正在服务器中跑着的时候发生了上述的OOM异常,那么怎么定位,如何下手解决呢?
此时,我们配置这样一个参数:

-XX:+HeapDumpOnOutOfMemoryError  配置oom时的dump快照
-XX:HeapDumpPath=表示生成DUMP文件的路径,也可以指定文件名称

程序加入配置:


dump文件配置.png

此时配置,如果发生OOM异常问题,那么就会为当前的内存问题创建快照,快照的路径在不制定的时候,默认是在当前项目的文件夹下!
测试结果:


测试结果.png

大家可以看出,java进程pid=4148出现了OOM异常,生成了.hprof的内存heap快照,接下来,我们针对这个快照利用工具进行分析!
jvisualvm

这个工具是jdk自带的,分析dump快照的工具,那么此时,我们用它打开我们刚刚创建的快照文件,进行分析!


jvisualvm分析dump文件.png

类内存占用率


jvisualvm类内存占有率.png

那么从这两张图中的检测结果以及我们的程序,我们可以清晰的发现出产生OOM异常引发问题的根源所在,并且能够轻松的排查问题!
那么本篇文章先给大家讲到这里,由于知识点过多的原因,这篇文章没能讲到去实战优化一个正在服务器中运行的项目,那么下一篇再去讲吧!下一篇也是jvm调优的最后一篇实战调优文章了!
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 216,142评论 6 498
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,298评论 3 392
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 162,068评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,081评论 1 291
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,099评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,071评论 1 295
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,990评论 3 417
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,832评论 0 273
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,274评论 1 310
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,488评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,649评论 1 347
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,378评论 5 343
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,979评论 3 325
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,625评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,796评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,643评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,545评论 2 352

推荐阅读更多精彩内容