如何监控JVM的垃圾回收

在Spring Boot项目里,可借助创建大量对象来触发GC,再运用工具监控GC时间并可视化展示。以下为具体步骤:

1. 创建Spring Boot项目

首先,你可以使用Spring Initializr(start.spring.io/ )创建一个基本的Spring Boot项目,添加Spring Web依赖。

2. 编写代码触发GC

src/main/java目录下创建一个新的类,代码如下:

java 复制代码
import org.springframework.boot.CommandLineRunner;
import org.springframework.stereotype.Component;

import java.util.ArrayList;
import java.util.List;

@Component
public class GCTrigger implements CommandLineRunner {

    @Override
    public void run(String... args) throws Exception {
        List<Object> list = new ArrayList<>();
        while (true) {
            list.add(new byte[1024 * 1024]); // 每次添加1MB的对象
            if (list.size() % 10 == 0) {
                System.gc(); // 手动触发GC
            }
        }
    }
}

在上述代码中,借助一个无限循环持续创建byte数组对象,并且每添加10个对象就手动触发一次GC。

3. 运行项目

启动Spring Boot项目,让代码开始运行。

4. 监控GC时间

你可以使用以下工具来监控GC时间:

VisualVM

VisualVM是一款功能强大的可视化监控工具,可用来监控Java应用程序的性能。

  • 安装 :如果你使用的是JDK 8及以前的版本,VisualVM通常会随JDK一同安装。要是使用JDK 9及以后的版本,你可以从VisualVM的官方网站(visualvm.github.io/ )下载并安装。
  • 监控:打开VisualVM,在左侧列表中找到你运行的Spring Boot项目,点击进入监控界面。在"监视"选项卡中,你能看到堆内存、非堆内存、线程等信息;在"垃圾回收"选项卡中,你可以看到GC的详细信息,如GC时间、GC次数等。

Java Mission Control (JMC)

Java Mission Control是Oracle提供的一款专业的性能监控和故障诊断工具。

  • 安装:如果你使用的是Oracle JDK,JMC通常会随JDK一起安装。要是使用OpenJDK,你可以从Oracle官方网站下载JMC。
  • 监控:打开JMC,连接到你运行的Spring Boot项目。在"飞行记录器"中,你可以创建一个新的记录,包含GC相关的事件。记录完成后,你可以分析GC事件的详细信息,包括GC时间、GC原因等。

5. 配置GC日志

除了使用可视化工具,你还可以通过配置GC日志来记录GC信息。在application.properties文件中添加以下配置:

properties 复制代码
java -XX:+PrintGCDetails -XX:+PrintGCDateStamps -Xloggc:gc.log

上述配置会将GC信息记录到gc.log文件中,你可以使用工具(如GCViewer)来分析这些日志文件。

总结

通过以上步骤,你可以在Spring Boot项目中触发GC,并使用可视化工具监控GC时间。这有助于你了解应用程序的内存使用情况和GC性能。

相关推荐
宋小黑9 分钟前
JDK 6到25 全版本网盘合集 (Windows + Mac + Linux)
java·后端
7哥♡ۣۖᝰꫛꫀꪝۣℋ20 分钟前
Spring-cloud\Eureka
java·spring·微服务·eureka
老毛肚33 分钟前
手写mybatis
java·数据库·mybatis
两点王爷36 分钟前
Java基础面试题——【Java语言特性】
java·开发语言
choke23340 分钟前
[特殊字符] Python 文件与路径操作
java·前端·javascript
choke23344 分钟前
Python 基础语法精讲:数据类型、运算符与输入输出
java·linux·服务器
岁岁种桃花儿1 小时前
CentOS7 彻底卸载所有JDK/JRE + 重新安装JDK8(实操完整版,解决kafka/jps报错)
java·开发语言·kafka
roman_日积跬步-终至千里2 小时前
【Java并发】Java 线程池实战:警惕使用CompletableFuture.supplyAsync
java·开发语言·网络
毕设源码-钟学长2 小时前
【开题答辩全过程】以 基于Springboot的扶贫众筹平台为例,包含答辩的问题和答案
java·spring boot·后端
CodeSheep程序羊2 小时前
拼多多春节加班工资曝光,没几个敢给这个数的。
java·c语言·开发语言·c++·python·程序人生·职场和发展