JVM工作原理与实战(三十三):监控GC过程的工具

本文涉及的产品
可观测可视化 Grafana 版,10个用户账号 1个月
日志服务 SLS,月写入数据量 50GB 1个月
可观测监控 Prometheus 版,每月50GB免费额度
简介: JVM作为Java程序的运行环境,其负责解释和执行字节码,管理内存,确保安全,支持多线程和提供性能监控工具,以及确保程序的跨平台运行。本文主要介绍了jstat工具、VisualVM插件、Prometheus + Grafana、GC日志等内容。

前言

JVM作为Java程序的运行环境,其负责解释和执行字节码,管理内存,确保安全,支持多线程和提供性能监控工具,以及确保程序的跨平台运行。本文主要介绍了jstat工具、VisualVM插件、Prometheus + Grafana、GC日志等内容。


一、监控GC过程的工具

为了确保监控工具能够更准确地发现Java垃圾回收(GC)时间过长、频率过高的现象,需要进行一些专业的配置和调整。下面将介绍一些常用的监控工具和技术,以及如何通过它们来改进对GC过程的监控。

jstat工具:

Jstat是JDK自带的一个非常实用的监控工具,它可以提供关于垃圾回收、类加载和编译的信息。为了更精确地监控GC过程,可以使用jstat工具的-gc选项,并指定一个进程ID。并且可以通过设置一个适当的统计间隔和次数,来获取GC的详细信息。

  • 优点: 无需安装额外的软件,操作简单。
  • 缺点: 无法精确地捕捉到GC的确切时间,主要用于判断GC是否存在问题。

案例:

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

VisualVM插件:

VisualVM是一个强大的Java性能分析工具,其中包含一个Visual GC插件,可以实时监控Java进程的堆内存结构、变化趋势以及垃圾回收时间的变化趋势。通过这个插件,可以直观地观察到堆内存和GC的变化情况。

  • 优点: 适合开发环境使用,能够直观地观察到堆内存和GC的变化趋势。
  • 缺点: 对程序运行性能有一定影响,且在生产环境中程序员通常没有权限进行操作。

案例:

image.gif

Prometheus + Grafana:

这是一个在生产环境中广泛使用的监控解决方案。Prometheus用于收集系统或应用数据,并具备告警功能。Grafana则可以将收集到的数据以可视化的方式展示出来。通过这些工具,可以对GC过程进行更深入的监控和分析。

优点:

  • 监控范围广:支持系统级别和应用级别的监控,如Linux操作系统、Redis、MySQL、Java进程等。
  • 告警功能:支持告警功能并允许自定义告警指标,通过邮件、短信等方式尽早通知相关人员处理。

缺点:

  • 环境搭建复杂:Prometheus和Grafana的环境搭建相对复杂,一般由专业的运维人员来完成。

image.gif

GC日志:

GC日志是了解垃圾回收过程的重要途径。通过分析这些日志,可以获取到关于垃圾回收的详细数据,并根据不同的垃圾回收器特点来发现潜在的问题。在JDK 8及以下版本中,可以通过-XX:+PrintGCDetails和-Xloggc:文件名选项来启用GC日志记录。在JDK 9及更高版本中,可以使用-Xlog:gc*:file=文件名选项来记录日志。

JDK 8及以下版本:

# 用于打印输出详细的GC收集日志的信息
-XX:+PrintGCDetails
# 将虚拟机每次垃圾回收的信息写到指定的日志文件中
-Xloggc:文件名

image.gif

JDK 9及更高版本:

# 将垃圾回收日志输出到指定的文件中
-Xlog:gc*:file=文件名

image.gif

案例:

image.gif

GCeasy:GCeasy是一个使用AI机器学习技术进行GC分析和诊断的工具。除了定位内存泄漏和GC延迟问题外,它还提供JVM参数优化的建议,并支持在线的可视化工具图表展示。

image.gif


总结

JVM是Java程序的运行环境,负责字节码解释、内存管理、安全保障、多线程支持、性能监控和跨平台运行。本文主要介绍了jstat工具、VisualVM插件、Prometheus + Grafana、GC日志等内容,希望对大家有所帮助。

相关文章
|
6月前
|
Oracle Java 关系型数据库
JVM深入原理(一+二):JVM概述和JVM功能
JVM全称是Java Virtual Machine-Java虚拟机JVM作用:本质上是一个运行在计算机上的程序,职责是运行Java字节码文件,编译为机器码交由计算机运行。
194 0
|
6月前
|
Arthas 存储 Java
JVM深入原理(三+四):JVM组成和JVM字节码文件
目录3. JVM组成3.1. 组成-运行时数据区3.2. 组成-类加载器3.3. 组成-执行引擎3.4. 组成-本地接口4. JVM字节码文件4.1. 字节码文件-组成4.1.1. 组成-基础信息4.1.1.1. 基础信息-魔数4.1.1.2. 基础信息-主副版本号4.1.2. 组成-常量池4.1.3. 组成-方法4.1.3.1. 方法-工作流程4.1.4. 组成-字段4.1.5. 组成-属性4.2. 字节码文件-查看工具4.2.1. javap4.2.2. jclasslib4.2.3. 阿里Arthas
126 0
|
6月前
|
存储 安全 Java
JVM深入原理(五):JVM组成和JVM字节码文件
类的生命周期概述:类的生命周期描述了一个类加载,使用,卸载的整个过类的生命周期阶段:类的声明周期主要分为五个阶段:加载->连接->初始化->使用->卸载,其中连接中分为三个小阶段验证->准备->解析。
105 0
|
6月前
|
Arthas Java 测试技术
JVM深入原理(六)(一):JVM类加载器
目录6. JVM类加载器6.1. 类加载器-概述6.2. 类加载器-执行流程6.3. 类加载器-分类(JDK8)6.3.1. JVM底层实现的类加载器6.3.1.1. 启动类加载器6.3.2. Java代码实现类的加载器6.3.2.1. 扩展类加载器6.3.2.2. 应用程序类加载器6.4. 类加载器-Arthas查看类加载器
129 0
|
6月前
|
Java 关系型数据库 MySQL
JVM深入原理(六)(二):双亲委派机制
自定义类加载器打破双亲委派机制的方法:复写ClassLoader中的loadClass方法常见问题:要加载的类名如果是以java.开头,则会抛出安全性异常加载自定义的类都会有一个共同的父类Object,需要在代码中交由父类加载器去加载自定义类加载器不手动指定parent会默认指定应用类加载两个自定义类加载器加载同一个类会被认为是两个对象,只有相同的类加载器+想通的类限定名才会被认为是一个对象。
245 0
|
6月前
|
Arthas 存储 算法
深入理解JVM,包含字节码文件,内存结构,垃圾回收,类的声明周期,类加载器
JVM全称是Java Virtual Machine-Java虚拟机JVM作用:本质上是一个运行在计算机上的程序,职责是运行Java字节码文件,编译为机器码交由计算机运行类的生命周期概述:类的生命周期描述了一个类加载,使用,卸载的整个过类的生命周期阶段:类的声明周期主要分为五个阶段:加载->连接->初始化->使用->卸载,其中连接中分为三个小阶段验证->准备->解析类加载器的定义:JVM提供类加载器给Java程序去获取类和接口字节码数据类加载器的作用:类加载器接受字节码文件。
660 55
|
1月前
|
存储 缓存 Java
我们来说一说 JVM 的内存模型
我是小假 期待与你的下一次相遇 ~
217 4
|
1月前
|
存储 缓存 算法
深入理解JVM《JVM内存区域详解 - 世界的基石》
Java代码从编译到执行需经javac编译为.class字节码,再由JVM加载运行。JVM内存分为线程私有(程序计数器、虚拟机栈、本地方法栈)和线程共享(堆、方法区)区域,其中堆是GC主战场,方法区在JDK 8+演变为使用本地内存的元空间,直接内存则用于提升NIO性能,但可能引发OOM。
|
7月前
|
Arthas 监控 Java
Arthas memory(查看 JVM 内存信息)
Arthas memory(查看 JVM 内存信息)
640 6
|
缓存 Prometheus 监控
Elasticsearch集群JVM调优设置合适的堆内存大小
Elasticsearch集群JVM调优设置合适的堆内存大小
2033 1