【jvm】Major GC

目录

          • [1. 说明](#1. 说明)
          • [2. 触发条件](#2. 触发条件)
          • [3. 执行过程](#3. 执行过程)
          • [4. 与Minor GC和Full GC的关系](#4. 与Minor GC和Full GC的关系)
            • [4.1 Minor GC](#4.1 Minor GC)
            • [4.1 Full GC](#4.1 Full GC)
          • [5. 优化建议](#5. 优化建议)
1. 说明
  • 1.Major GC,即老年代GC,指的是发生在老年代(Old Generation或Tenured Generation)的垃圾回收过程。
  • 2.Major即主要的。
2. 触发条件
  • 1.Major GC的主要触发条件是老年代空间不足
  • 2.存活对象从年轻代(Young Generation)晋升到老年代,导致老年代空间不足。
  • 3.应用程序创建了大量大对象,这些对象直接进入老年代,占用了大量空间。
  • 4.在Java 8及之前的版本中,如果永久代(PermGen)空间不足,也可能触发Major GC(尽管这更多与Full GC相关,但在某些情况下可能涉及老年代的回收)。
  • 5.在Java 8及之后的版本中,永久代被元空间(Metaspace)取代,因此这一触发条件不再适用。
3. 执行过程
  • 1.标记阶段:遍历堆内存中的对象,标记出存活的对象。
  • 2.整理阶段:根据标记结果,移动存活对象以减少碎片化,并释放不再需要的对象所占用的空间。
  • 3.这个过程可能导致较长的停顿时间,因为需要整理老年代的内存并移动对象。
  • 4.Major GC的执行速度通常比Minor GC慢得多。
4. 与Minor GC和Full GC的关系
4.1 Minor GC
  • 1.主要关注清理年轻代的内存区域。
  • 2.当年轻代中的Eden区或Survivor区满时,会触发Minor GC。
  • 3.Minor GC通常发生频繁,但停顿时间相对较短。
4.1 Full GC
  • 1.是对整个堆内存(包括年轻代、老年代、永久代或Metaspace等)进行清理的一种垃圾回收操作。
  • 2.Full GC的触发条件可能包括老年代空间不足、永久代/Metaspace空间不足或显式调用System.gc()等。
  • 3.Full GC的执行会导致相对较长的停顿时间,因为它需要对整个堆内存进行回收。
  • 4.很多时候Major GC会和Full GC混淆使用。
  • 5.Major GC主要关注老年代的垃圾回收,而Full GC则是对整个堆内存的完全清理。
  • 6.在某些情况下,如CMS并发清理过程中出现"并发分配错误"时,会触发对所有堆空间进行回收的Full GC。
5. 优化建议
  • 1.为了减少Major GC的频率和停顿时间。
  • 2.调整堆内存大小:根据应用程序的需求调整堆内存的大小,以确保有足够的空间容纳存活对象。
  • 3.优化对象晋升策略:通过调整年轻代和老年代的比例、设置晋升阈值等方式来优化对象的晋升策略。
  • 4.使用更高效的垃圾回收器:根据应用程序的特点选择合适的垃圾回收器,如G1 GC、ZGC等,这些回收器在性能和停顿时间方面通常优于传统的Serial和Parallel GC。
相关推荐
__土块__1 小时前
大厂后端一面模拟:从线程安全到分布式缓存的连环追问
jvm·redis·mysql·spring·java面试·concurrenthashmap·大厂后端
fly spider10 小时前
一文概括 JVM 核心内容
jvm
brahmsjiang10 小时前
Java类加载机制解析:从JVM启动到双亲委派,再到Android的特殊实现
android·java·jvm
cch891810 小时前
C++、Python与汇编语言终极对比
java·开发语言·jvm
zshs00010 小时前
从 HashMap 到基因法:同一套位运算思想,如何从 JVM 走到分布式数据库
jvm·数据库·分布式
彧翎Pro19 小时前
基于 RO1 noetic 配置 robosense Helios 32(速腾) & xsense mti 300
前端·jvm
minji...1 天前
Linux 线程同步与互斥(二) 线程同步,条件变量,pthread_cond_init/wait/signal/broadcast
linux·运维·开发语言·jvm·数据结构·c++
woai33641 天前
JVM学习-基础篇-常见引用
jvm·学习
それども1 天前
理解JVM参数 Xss 线程的栈大小
jvm
玛卡巴卡ldf1 天前
【Springboot6】内存泄漏OOM、VisualVM、Arthas、Prometheus Grafana监控、垃圾回收
java·jvm·springboot