前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >每日一面 - java中,MinorGC、MajorGC、FullGC 什么时候发生?

每日一面 - java中,MinorGC、MajorGC、FullGC 什么时候发生?

作者头像
干货满满张哈希
发布2021-04-12 13:46:18
4120
发布2021-04-12 13:46:18
举报
文章被收录于专栏:干货满满张哈希

问题引用自: https://www.zhihu.com/question/437493648/answer/1656737915,答案为个人原创

MinorGC 一般指清理 Young space (Eden and Survivor spaces) 的 GC。例如 G1GC 还有 ShenandoahGC 中的 YoungGC. 触发一般是:

  • Allocation Failure: 分配对象失败,空间不足. 内存分配流程,涉及到了 bump-the-pointer, TLAB,Allocation Prematch 这些机制, 请参考
  • Survivor 区满了,需要拷贝

不同的 GC 还会有自己个性化的触发机制,例如 G1GC 还有Shenandoah GC 的 TLAB 分配失败剩余空间大于最大浪费空间直接在Eden分配也失败,ZGC 的预热触发等等。

MajorGC 一般指清理 Tenured space 的 GC。例如 G1GC 还有 ShenandoahGC 中的 OldGC. 一般由 MinorGC 触发,并且回收的空间依然不足,则可能触发 MajorGC。还有一些特殊的机制,例如 G1GC 的Homongous Allocation(大对象分配),在分配超过 RegionSize 一半大小的对象时,会触发 OldGC。 FullGC 一般指清理 所有 space 的 GC。触发时机一般是:

  • System.gc()被调用并且没有指定关闭显示GC,就是没有指定-XX:+DisableExplicitGC这个JVM flag
  • 老年代也满了
  • 堆外内存满了(JVM内存结构请参考:谁能给我详细讲解一下JVM的详细内存?),例如metaspace,代码即时编译缓存,直接内存,mmap内存
  • gc 担保失败,请参考:-XX:-HandlePromotionFailure

一般的,我们现在不会去太关心到底是哪种 GC,而是主要关心哪些 GC STW 的时间长,导致所有线程停止工作的时间长,关于为何会 STW 以及所有出发 STW 的 JVM机制以及如何优化,请参考我的另一篇文章: JVM相关 - SafePoint 与 Stop The World 全解

想模拟 GC 的各种情况,可以通过 WhiteBox API,参考:JVM 相关 - 深入 JVM 的钥匙 WhiteBox API

关于如何通过日志查看 GC 详情,请参考:OpenJDK 11 JVM日志相关参数解析与使用

关于如何通过 JFR 快速可视化定位 GC 问题,请参考: JFR全解

通过JFR与日志深入探索JVM

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2021/01/02 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档