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

本文涉及的产品
日志服务 SLS,月写入数据量 50GB 1个月
可观测可视化 Grafana 版,10个用户账号 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日志等内容,希望对大家有所帮助。

相关文章
|
5月前
|
监控 Java Unix
6个Java 工具,轻松分析定位 JVM 问题 !
本文介绍了如何使用 JDK 自带工具查看和分析 JVM 的运行情况。通过编写一段测试代码(启动 10 个死循环线程,分配大量内存),结合常用工具如 `jps`、`jinfo`、`jstat`、`jstack`、`jvisualvm` 和 `jcmd` 等,详细展示了 JVM 参数配置、内存使用、线程状态及 GC 情况的监控方法。同时指出了一些常见问题,例如参数设置错误导致的内存异常,并通过实例说明了如何排查和解决。最后附上了官方文档链接,方便进一步学习。
618 4
|
9月前
|
算法 网络协议 Java
【JVM】——GC垃圾回收机制(图解通俗易懂)
GC垃圾回收,标识出垃圾(计数机制、可达性分析)内存释放机制(标记清除、复制算法、标记整理、分代回收)
|
9月前
|
NoSQL Java Redis
秒杀抢购场景下实战JVM级别锁与分布式锁
在电商系统中,秒杀抢购活动是一种常见的营销手段。它通过设定极低的价格和有限的商品数量,吸引大量用户在特定时间点抢购,从而迅速增加销量、提升品牌曝光度和用户活跃度。然而,这种活动也对系统的性能和稳定性提出了极高的要求。特别是在秒杀开始的瞬间,系统需要处理海量的并发请求,同时确保数据的准确性和一致性。 为了解决这些问题,系统开发者们引入了锁机制。锁机制是一种用于控制对共享资源的并发访问的技术,它能够确保在同一时间只有一个进程或线程能够操作某个资源,从而避免数据不一致或冲突。在秒杀抢购场景下,锁机制显得尤为重要,它能够保证商品库存的扣减操作是原子性的,避免出现超卖或数据不一致的情况。
267 10
|
10月前
|
Arthas Prometheus 监控
监控堆外使用JVM工具
监控堆外使用JVM工具
275 7
|
10月前
|
存储 监控 Java
JVM进阶调优系列(8)如何手把手,逐行教她看懂GC日志?| IT男的专属浪漫
本文介绍了如何通过JVM参数打印GC日志,并通过示例代码展示了频繁YGC和FGC的场景。文章首先讲解了常见的GC日志参数,如`-XX:+PrintGCDetails`、`-XX:+PrintGCDateStamps`等,然后通过具体的JVM参数和代码示例,模拟了不同内存分配情况下的GC行为。最后,详细解析了GC日志的内容,帮助读者理解GC的执行过程和GC处理机制。
|
11月前
|
Arthas 监控 数据可视化
JVM进阶调优系列(7)JVM调优监控必备命令、工具集合|实用干货
本文介绍了JVM调优监控命令及其应用,包括JDK自带工具如jps、jinfo、jstat、jstack、jmap、jhat等,以及第三方工具如Arthas、GCeasy、MAT、GCViewer等。通过这些工具,可以有效监控和优化JVM性能,解决内存泄漏、线程死锁等问题,提高系统稳定性。文章还提供了详细的命令示例和应用场景,帮助读者更好地理解和使用这些工具。
|
10月前
|
存储 IDE Java
实战优化公司线上系统JVM:从基础到高级
【11月更文挑战第28天】Java虚拟机(JVM)是Java语言的核心组件,它使得Java程序能够实现“一次编写,到处运行”的跨平台特性。在现代应用程序中,JVM的性能和稳定性直接影响到系统的整体表现。本文将深入探讨JVM的基础知识、基本特点、定义、发展历史、主要概念、调试工具、内存管理、垃圾回收、性能调优等方面,并提供一个实际的问题demo,使用IntelliJ IDEA工具进行调试演示。
145 0
|
4月前
|
Arthas 存储 算法
深入理解JVM,包含字节码文件,内存结构,垃圾回收,类的声明周期,类加载器
JVM全称是Java Virtual Machine-Java虚拟机JVM作用:本质上是一个运行在计算机上的程序,职责是运行Java字节码文件,编译为机器码交由计算机运行类的生命周期概述:类的生命周期描述了一个类加载,使用,卸载的整个过类的生命周期阶段:类的声明周期主要分为五个阶段:加载->连接->初始化->使用->卸载,其中连接中分为三个小阶段验证->准备->解析类加载器的定义:JVM提供类加载器给Java程序去获取类和接口字节码数据类加载器的作用:类加载器接受字节码文件。
449 55
|
5月前
|
Arthas 监控 Java
Arthas memory(查看 JVM 内存信息)
Arthas memory(查看 JVM 内存信息)
416 6
|
8月前
|
存储 设计模式 监控
快速定位并优化CPU 与 JVM 内存性能瓶颈
本文介绍了 Java 应用常见的 CPU & JVM 内存热点原因及优化思路。
901 166