【jvm】Full GC

目录

          • [1. 说明](#1. 说明)
          • [2. 触发条件](#2. 触发条件)
          • [3. 优化](#3. 优化)
          • [4. 注意事项](#4. 注意事项)
1. 说明
  • 1.Full GC(Full Garbage Collection)是Java垃圾回收过程中最重要且最昂贵的一种操作。
  • 2.Full GC涉及对整个堆内存(包括年轻代老年代)的垃圾回收。
  • 3.当Full GC发生时,JVM会暂停所有的应用程序线程,直到垃圾回收完成,这种暂停被称为"Stop-the-World"(STW)事件。
  • 4.由于Full GC需要对整个堆进行扫描和清理,因此它会比只回收年轻代的垃圾回收(Minor GC)耗费更多的时间和资源。
2. 触发条件
  • 1.老年代空间不足:当老年代空间不足以容纳新创建的对象或被提升的对象时,会触发Full GC。
  • 2.永久代/元空间不足:永久代/元空间主要用于存储类的元数据和静态信息,因此类加载过多或类定义过多时,可能会导致Full GC。
  • 3.手动执行GC命令:使用System.gc()方法或调用Runtime.getRuntime().gc()方法可以手动触发Full GC,但这是一个建议,JVM可以选择执行。
  • 4.年代晋升失败:如对象从年轻代晋升到老年代时,老年代没有足够的空间容纳这些对象,也会触发Full GC。
  • 5.CMS的Concurrent-Mode-Failure:在使用CMS(Concurrent Mark-Sweep)垃圾收集器时,如果在Minor GC之后没有足够的空间在老年代容纳晋升对象,会触发Full GC。
  • 6.G1垃圾收集器的特殊情况:在使用G1垃圾收集器时,如果在年轻代GC后无法找到足够的连续空闲内存空间来放置所有存活对象,也会触发Full GC。
3. 优化
  • 1.调整堆的大小:通过增加老年代的大小或减少年轻代的大小,可以减少老年代空间不足而触发的Full GC。同时,设置合理的初始堆大小和最大堆大小,使得JVM启动时堆内存就达到适合的大小,减少堆扩展时可能的Full GC。
  • 2.使用合适的垃圾收集器:根据应用程序的特点选择适合的垃圾收集器可以更好地平衡内存占用和性能。例如,对于需要低延迟的应用程序,可以选择使用CMS或G1垃圾收集器。
  • 3.减少对象产生:通过对象的复用、使用对象池等方式减少对象的产生,可以降低GC的负担,从而减少Full GC的发生。
  • 4.分析Full GC日志:仔细分析Full GC日志可以帮助找出导致Full GC的根本原因。通过分析日志中的堆内存使用情况、垃圾收集时间和回收的内存量等信息,可以找到潜在的问题并进行相应的优化。
4. 注意事项
  • 1.避免频繁调用System.gc():在代码中尽量避免频繁调用System.gc()方法,因为这可能会引起不必要的Full GC。
  • 2.监控内存使用情况:使用JVM提供的监控工具(如jstat、visualvm等)监控内存使用情况,及时发现并处理内存泄漏等问题。
  • 3.选择合适的JVM参数:根据应用程序的需求选择合适的JVM参数,如堆大小、垃圾收集器类型等,以优化性能。
相关推荐
阿龟在奔跑3 小时前
引用类型的局部变量线程安全问题分析——以多线程对方法局部变量List类型对象实例的add、remove操作为例
java·jvm·安全·list
王佑辉3 小时前
【jvm】方法区常用参数有哪些
jvm
王佑辉3 小时前
【jvm】HotSpot中方法区的演进
jvm
Domain-zhuo3 小时前
什么是JavaScript原型链?
开发语言·前端·javascript·jvm·ecmascript·原型模式
Theodore_10221 天前
7 设计模式原则之合成复用原则
java·开发语言·jvm·设计模式·java-ee·合成复用原则
我是苏苏1 天前
Web开发:ORM框架之使用Freesql的DbFrist封装常见功能
java·前端·jvm
天草二十六_简村人1 天前
Java语言编程,通过阿里云mongo数据库监控实现数据库的连接池优化
java·jvm·数据库·mongodb·阿里云·微服务·云计算
老码沉思录1 天前
Android开发实战班 - 数据持久化 - Room 数据库应用
android·jvm·数据库
起名字真南1 天前
【C++】深入理解 C++ 中的继承进阶:多继承、菱形继承及其解决方案
java·jvm·c++·chatgpt·aigc
偶尔。5351 天前
JVM垃圾回收算法详解
jvm