当前位置: 首页 > news >正文

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

文章目录

  • 1、调优的主要指标
  • 2、工具一:jstat
  • 3、工具二:Visual VM的插件
  • 4、工具三:Prometheus + Grafana
  • 5、生成GC日志
  • 6、工具四:GC Viewer
  • 7、工具五:GCeasy

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/

在这里插入图片描述

生成的报告:

在这里插入图片描述

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

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

http://www.lryc.cn/news/326801.html

相关文章:

  • SpringCloudConfig 使用git搭建配置中心
  • c#基础-引用类型和值类型的区别
  • 面试题-3.20
  • glibc内存管理ptmalloc - 多线程内存管理
  • 区块链食品溯源案例实现(一)
  • 4S店车辆管理系统的设计与实现|Springboot+ Mysql+Java+ B/S结构(可运行源码+数据库+设计文档)
  • SpringBoot+Prometheus+Grafana实现应用监控和报警
  • 10 - Debian如何让特定用户切换root身份
  • HPT发布HyperGAI 多模态大模型:性能领先GPT-4V,全面胜过Gemini Pro
  • 汇春科技之MDT10F684
  • 【Vue3笔记01】如何使用Vue3和Vite搭建前端项目的基础开发环境
  • 软考高级架构师:信息安全概念和例题
  • Lilishop商城(windows)本地部署【docker版】
  • # 14 React 自定义Hook详解
  • HTML静态网页成品作业(HTML+CSS+JS)——中华美食八大菜系介绍(1个页面)
  • PostgreSQL11 | Windows系统安装PostgreSQL
  • uniapp保留两位小数,整数后面加.00
  • R: 网状Meta分析进行模型构建及图形绘制
  • 数据结构——排序算法
  • MyBatis的高级特性探索
  • 未来制造:机器人行业新质生产力提升策略
  • 开发过程中PostgreSQL常用的SQL语句,持续更新ing
  • Linux screen命令教程:如何在一个终端窗口中管理多个会话(附实例详解和注意事项)
  • Android中的本地广播与全局广播
  • Debezium日常分享系列之:Debezium2.5稳定版本之MySQL连接器配置示例和Connector参数详解
  • vue3父组件给子组件传值,并在子组件接受
  • Python爬虫如何快速入门
  • 酷开科技依托酷开系统用“平台+产品+场景”塑造全屋智能生活!
  • P8649 [蓝桥杯 2017 省 B] k 倍区间:做题笔记
  • LeetCode题练习与总结:旋转图像