深入理解Java虚拟机(四)——JVM性能调优监控工具

 2019-12-22 10:31  阅读(929)
文章分类:JVM

目录

深入理解Java虚拟机(一)——JVM整体架构

深入理解Java虚拟机(二)——类加载器深入解析

深入理解Java虚拟机(三)——JVM内存结构+JVM执行引擎

深入理解Java虚拟机(四)——JVM性能调优监控工具

Jinfo

查看正在运行的Java应用程序的扩展参数

查看jvm的参数

201912000186\_1.png

查看java系统参数

201912000186\_2.png

Jstat

jstat命令可以查看堆内存各部分的使用量,以及加载类的数量。命令的格式如下:

jstat [-命令选项] [vmid] [间隔时间/毫秒] [查询次数]

注意:使用的jdk版本是jdk8.

类加载统计:

201912000186\_3.png

  1. Loaded:加载class的数量
  2. Bytes:所占用空间大小
  3. Unloaded:未加载数量
  4. Bytes:未加载占用空间
  5. Time:时间

垃圾回收统计

201912000186\_4.png

  1. S0C:第一个幸存区的大小
  2. S1C:第二个幸存区的大小
  3. S0U:第一个幸存区的使用大小
  4. S1U:第二个幸存区的使用大小
  5. EC:伊甸园区的大小
  6. EU:伊甸园区的使用大小
  7. OC:老年代大小
  8. OU:老年代使用大小
  9. MC:方法区大小(元空间)
  10. MU:方法区使用大小
  11. CCSC:压缩类空间大小
  12. CCSU:压缩类空间使用大小
  13. YGC:年轻代垃圾回收次数
  14. YGCT:年轻代垃圾回收消耗时间
  15. FGC:老年代垃圾回收次数
  16. FGCT:老年代垃圾回收消耗时间
  17. GCT:垃圾回收消耗总时间

堆内存统计

201912000186\_5.png

  1. NGCMN:新生代最小容量
  2. NGCMX:新生代最大容量
  3. NGC:当前新生代容量
  4. S0C:第一个幸存区大小
  5. S1C:第二个幸存区的大小
  6. EC:伊甸园区的大小
  7. OGCMN:老年代最小容量
  8. OGCMX:老年代最大容量
  9. OGC:当前老年代大小
  10. OC:当前老年代大小
  11. MCMN:最小元数据容量
  12. MCMX:最大元数据容量
  13. MC:当前元数据空间大小
  14. CCSMN:最小压缩类空间大小
  15. CCSMX:最大压缩类空间大小
  16. CCSC:当前压缩类空间大小
  17. YGC:年轻代gc次数
  18. FGC:老年代GC次数

新生代垃圾回收统计

201912000186\_6.png

  1. S0C:第一个幸存区的大小
  2. S1C:第二个幸存区的大小
  3. S0U:第一个幸存区的使用大小
  4. S1U:第二个幸存区的使用大小
  5. TT:对象在新生代存活的次数
  6. MTT:对象在新生代存活的最大次数
  7. DSS:期望的幸存区大小
  8. EC:伊甸园区的大小
  9. EU:伊甸园区的使用大小
  10. YGC:年轻代垃圾回收次数
  11. YGCT:年轻代垃圾回收消耗时间

新生代内存统计

201912000186\_7.png

  1. NGCMN:新生代最小容量
  2. NGCMX:新生代最大容量
  3. NGC:当前新生代容量
  4. S0CMX:最大幸存1区大小
  5. S0C:当前幸存1区大小
  6. S1CMX:最大幸存2区大小
  7. S1C:当前幸存2区大小
  8. ECMX:最大伊甸园区大小
  9. EC:当前伊甸园区大小
  10. YGC:年轻代垃圾回收次数
  11. FGC:老年代回收次数

老年代垃圾回收统计

201912000186\_8.png

  1. MC:方法区大小
  2. MU:方法区使用大小
  3. CCSC:压缩类空间大小
  4. CCSU:压缩类空间使用大小
  5. OC:老年代大小
  6. OU:老年代使用大小
  7. YGC:年轻代垃圾回收次数
  8. FGC:老年代垃圾回收次数
  9. FGCT:老年代垃圾回收消耗时间
  10. GCT:垃圾回收消耗总时间

老年代内存统计

201912000186\_9.png

  1. OGCMN:老年代最小容量
  2. OGCMX:老年代最大容量
  3. OGC:当前老年代大小
  4. OC:老年代大小
  5. YGC:年轻代垃圾回收次数
  6. FGC:老年代垃圾回收次数
  7. FGCT:老年代垃圾回收消耗时间
  8. GCT:垃圾回收消耗总时间

元数据空间统计

201912000186\_10.png

  1. MCMN:最小元数据容量
  2. MCMX:最大元数据容量
  3. MC:当前元数据空间大小
  4. CCSMN:最小压缩类空间大小
  5. CCSMX:最大压缩类空间大小
  6. CCSC:当前压缩类空间大小
  7. YGC:年轻代垃圾回收次数
  8. FGC:老年代垃圾回收次数
  9. FGCT:老年代垃圾回收消耗时间
  10. GCT:垃圾回收消耗总时间

201912000186\_11.png

  1. S0:幸存1区当前使用比例
  2. S1:幸存2区当前使用比例
  3. E:伊甸园区使用比例
  4. O:老年代使用比例
  5. M:元数据区使用比例
  6. CCS:压缩使用比例
  7. YGC:年轻代垃圾回收次数
  8. FGC:老年代垃圾回收次数
  9. FGCT:老年代垃圾回收消耗时间
  10. GCT:垃圾回收消耗总时间

Jmap

此命令可以用来查看内存信息。

实例个数以及占用内存大小

201912000186\_12.png

打开log.txt,文件内容如下:

201912000186\_13.png

  1. num:序号
  2. instances:实例数量
  3. bytes:占用空间大小
  4. class name:类名称

堆信息

201912000186\_14.png

堆内存dump

201912000186\_15.png

也可以设置内存溢出自动导出dump文件(内存很大的时候,可能会导不出来)

  1. -XX:+HeapDumpOnOutOfMemoryError
  2. -XX:HeapDumpPath=./ (路径)

201912000186\_16.png

可以用jvisualvm命令工具导入该dump文件分析

201912000186\_17.png

Jstack

201912000186\_18.png

用jstack查找死锁,见如下示例,也可以用jvisualvm查看死锁

201912000186\_19.png

201912000186\_20.png

远程连接jvisualvm

启动普通的jar程序JMX端口配置:

java -Dcom.sun.management.jmxremote.port=12345 -Dcom.sun.management.jmxremote.ssl=false -Dcom.sun.management.jmxremote.authenticate=false -jar foo.jar

tomcat的JMX配置

JAVA_OPTS=-Dcom.sun.management.jmxremote.port=8999 -Dcom.sun.management.jmxremote.ssl=false -Dcom.sun.management.jmxremote.authenticate=false

jvisualvm远程连接服务需要在远程服务器上配置host(连接ip 主机名),并且要关闭防火墙

jstack找出占用cpu最高的堆栈信息

1,使用命令top -p ,显示你的java进程的内存情况,pid是你的java进程号,比如4977

2,按H,获取每个线程的内存情况

3,找到内存和cpu占用最高的线程tid,比如4977

4,转为十六进制得到 0x1371 ,此为线程id的十六进制表示

5,执行 jstack 4977|grep -A 10 1371,得到线程堆栈信息中1371这个线程所在行的后面10行

6,查看对应的堆栈信息找出可能存在问题的代码

点赞(0)
版权归原创作者所有,任何形式转载请联系作者; Java 技术驿站 >> 深入理解Java虚拟机(四)——JVM性能调优监控工具

相关推荐