【开发篇】十一、GC调优的分析工具


GC调优,是为了避免因垃圾回收引起程序性能下降,包括:

  • 通用JVM参数设置
  • 特定GC回收器的JVM参数设置
  • 解决频繁Full GC引起的程序性能问题

GC调优无标准答案,视不同的服务器配置、硬件、服务器可用资源等的影响

1、调优的主要指标

监控工具发现了存在GC时间过长或频率过高的现象后,通过分析工具排查原因,调整JVM参数或者修改代码。调优指标:

1GC吞吐量

CPU 用于执行用户代码的时间与 CPU 总执行时间的比值。如下,JVM运行的100s内,GC花1s,则吞吐为99%
在这里插入图片描述

2)延迟

用户发送请求到收到响应的时间,等于GC时间+业务代码执行时间
在这里插入图片描述

3)内存使用量

Java应用占用系统内存的最大值

2、工具一:jstat

JDK自带的监控工具:

jstat -gc 进程ID 每次统计的间隔(毫秒) 统计次数

在这里插入图片描述

每列的含义:

  • C代表Capacity容量,U代表Used使用量
  • S – 幸存者区,E – 伊甸园区,O – 老年代,M – 元空间
  • YGC、YGT:年轻代GC次数和GC耗时(单位:秒)
  • FGC、FGCT:Full GC次数和Full GC耗时
  • GCT:GC总耗时

3、工具二:Visual VM的插件

可展示:堆内存结构及变化趋势、垃圾回收时间、对象晋升信息。安装插件:

在这里插入图片描述

网络问题,直接安装超时,自己下载一个,走本地安装。【下载

//下载地址
https://visualvm.github.io/pluginscenters.html

在这里插入图片描述
点击下载

在这里插入图片描述

下载完成后,Visual VM中选择从本地安装:

在这里插入图片描述
IDEA中启动程序,查看

在这里插入图片描述

4、工具三:Prometheus + Grafana

在这里插入图片描述

在这里插入图片描述

读图:

在这里插入图片描述

5、生成GC日志

控制台打印gc日志:

-verbose:gc

下面的工具是分析GC日志文件,生成文件可加JVM参数:

//JDK8及以下
-XX:+PrintGCDetails -Xloggc:文件名
//JDK9+
-Xlog:gc*:file=文件名

6、工具四:GC Viewer

GC日志转可视化图表的小工具:

//github地址:
https://github.com/chewiebug/GCViewe

使用:

java -jar gcviewer_1.3.4.jar 日志文件.log

在这里插入图片描述
打开GC Viewer:

在这里插入图片描述

7、工具五:GCeasy

AI,可定位内存泄漏、GC延迟高的问题,提供JVM参数优化建议,支持在线的可视化工具图表展示。官方网站:

https://gceasy.io/

在这里插入图片描述

生成的报告:

在这里插入图片描述

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

这款最舒适,但有免费的分析次数有限制。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

-代号9527

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值