`
ol_beta
  • 浏览: 291347 次
  • 性别: Icon_minigender_1
  • 来自: 天津
社区版块
存档分类
最新评论

Garbage First(G1)介绍

    博客分类:
  • jvm
阅读更多

介绍:

Garbage First(G1)致力于在多CPU和大内存服务器上对垃圾收集提供软实时目标(soft real-time goal )和高吞吐量(high throughput )。从JDK 6u14开始就已经在Hotspot上试验,到现在的DK7依然没有走出实验室:

#java -version
java version "1.7.0_03"
Java(TM) SE Runtime Environment (build 1.7.0_03-b05)
Java HotSpot(TM) 64-Bit Server VM (build 22.1-b02, mixed mode)

#java -server -XX:+PrintFlagsFinal | grep UseG1GC
bool UseG1GC                                   = false           {product}

 

关于region:

在G1中,heap被平均分成若干个大小相等的区域(region)。每个region都有一个关联的remembered set (RS),RS的数据结构是hash table,里面的数据是card table (heap中每512byte映射在card table 1byte)。简单的说RS里面存在的是region中live objects的指针。当region中数据发生变化时,首先反映到card table中的一个或多个card上,RS通过扫描内部的card table得知region中内存使用情况和存活对象。

关于内存分配:

由于G1主要关注于多CPU多线程,所以内存分配采用 thread-local allocation buffers (TLABs)技术。每个分配线程都有一个自己的buffers用来分配对象,当buffers用完或者不够的时候,去重新申请一块内存放在自己的thread-local里面。这样对象的内存分配被最小化到私有的buffers里面,缓解了并发分配内存的压力。

当region被填满后,分配内存的线程会重新选择一个新的region。空region被组织到一个linked list里面,这样可以快速找到新的region。

对于大对象的分配不是在TLABs进行的,而是在TLABs之外。当一个对象的大小超过region的3/4的时候,这个对象被认为是巨大的(humongous )。巨大的对象被分配到特殊的区域(heap regions )。这些区域只包含巨大对象(humongous object )。

执行过程:

  • 初始标记 :Initial Marking
  • 并发标记 :Concurrent Marking
  • 最终标记 :Final Marking
  • 计数并清理 :Live Data Counting and Cleanup

G1执行的第一阶段是初始标记(Initial Marking ),这个阶段是STW(Stop the World )的,所有mutator threads将被停止,标记出从GC Root开始直接可达的对象。然后,所有mutator threads将被重启,进入并发标记(Concurrent Marking )阶段。这个阶段从GC Root开始对heap中的对象标记,标记线程与应用程序线程并行直接,耗时较长。当并发标记完成后,开始最终标记(Final Marking )阶段。这个阶段主要是标记那些在并发标记阶段发生变化的对象。同样最终标记也要STW,但是多个标记线程并行运行,很快就可以完成。最后一个阶段会对每个区域(region)的回收成本和价值进行排序,根据用户指定的停顿时间,选择性的收集某些区域的对象,并统计每个区域对象的数量。

与CMS对比:

总体来说,G1跟CMS一样,是一块低延时的收集器,同样牺牲了吞吐量,不过二者之间得到了很好的权衡。

G1与CMS对比有一下不同:

1.分代: CMS中,堆被分为PermGen,YoungGen,OldGen;而YoungGen又分了两个survivo区域。在G1中,堆被平均分成几个区域(region),在每个区域中,虽然也保留了新老代的概念,但是收集器是以整个区域为单位收集的。

2.算法: 相对于CMS的“标记——清理”算法,G1会使用压缩算法,保证不产生多余的碎片。收集阶段,G1会将某个区域存活的对象拷贝的其他区域,然后将整个区域整个回收。

3.停顿时间可控: 为了缩短停顿时间,G1建立可预存停顿模型,这样在用户设置的停顿时间范围内,G1会选择适当的区域进行收集,确保停顿时间不超过用户指定时间。

 

 

参考资料:见附件

 

分享到:
评论

相关推荐

    Garbage-First_garbage_collection g1垃圾免积分下载

    G1垃圾回收器(Garbage-First Garbage Collection)是针对拥有大量内存和多处理器的服务器端应用而设计的一种垃圾回收机制。它能够在高概率的情况下满足软实时目标,同时还能达到较高的吞吐量。G1垃圾回收器能够在...

    Garbage-First LSM 论文

    Garbage-First is a server-style garbage collector, targeted for multi-processors with large memories, that meets a soft real-time goal with high probability, while achieving high throughput. Whole-...

    G1(Garbage -First).xmind

    G1垃圾收集器的总体流程与重要算法

    GarbageFirst

    本文将详细介绍Garbage-First(G1)垃圾回收器,它是一种针对多处理器且具有大内存系统的服务器级别的垃圾回收机制。G1的目标是在高概率下满足软实时目标的同时实现高吞吐量。为避免与应用程序运行时成比例的中断...

    【Java 8 GC 调优】Garbage-First(G1)

    G1 是一个 服务器风格(Server-Style)的垃圾收集器。其适用目标是具有大内存的多处理器计算机。它试图在实现高吞吐量的同时,高概率地满足 GC暂停时间 目标。整个堆操作,如 全局标记,与业务线程同时运行。这可以...

    深入理解JVM&G1; GC

    《深入理解JVM & G1 GC》一书深入剖析了Java虚拟机(JVM)的工作原理,特别是针对垃圾收集器(GC)中的G1(Garbage-First)算法进行了详尽的探讨。JVM是Java程序运行的基础,它负责解析、编译、执行Java代码,并管理...

    Java理解G1垃圾收集器.pdf

    Java的G1(Garbage First)垃圾收集器是一种先进的垃圾回收机制,主要设计目标是实现低延迟、高吞吐量的内存管理。G1垃圾收集器是Java虚拟机(JVM)的一部分,它引入了区域(Region)的概念,将堆内存划分为多个固定...

    JVM&g1gc;带书签,完整版本

    G1(Garbage-First)是Oracle JDK从1.6版本开始引入的一种垃圾收集器,设计目标是实现低延迟的内存回收,尤其适合大规模分布式系统。G1垃圾收集器采用了一种全新的内存区域划分方式,将Java堆划分为多个大小相等的...

    G1垃圾回收器论文【免积分下载】

    《Garbage-First Garbage Collection》这篇论文不仅详细介绍了G1垃圾回收器的设计思想和技术特点,还展示了如何通过先进的垃圾回收技术解决大型服务器应用所面临的挑战。G1垃圾回收器通过并发标记、区域划分、并行...

    Understanding_Java_Garbage_Collection_v4.pdf

    接下来,文档介绍了商用JVM的几种实现方式,包括Oracle HotSpot的并行垃圾回收器(Parallel GC)、并发标记清除垃圾回收器(CMS)和G1垃圾回收器(Garbage First)。文档还提到了Azul Systems的Zing C4垃圾回收器。...

    03 GarbageCollection.zip

    在实际的Java虚拟机(JVM)中,垃圾收集器通常结合了多种策略,例如G1(Garbage-First)收集器就是一种分代、并行、并发的垃圾收集器,它试图最小化垃圾收集的停顿时间,以提高用户体验。 了解和掌握垃圾收集机制,...

    深入理解JVM & G1 GC

    《深入理解JVM & G1 GC》这篇文章和相关压缩包文件主要聚焦于Java虚拟机(JVM)的内存管理,特别是垃圾收集器(GC)的优化,特别是G1(Garbage-First)垃圾收集器的深度解析。下面将详细阐述JVM、GC的基本概念,...

    The Garbage Collection Handbook(垃圾回收器手册).7z

    4. **垃圾收集器类型**:Java虚拟机(JVM)提供了多种垃圾收集器,如Serial、Parallel、Parallel Old、CMS(Concurrent Mark Sweep)、G1(Garbage-First)和ZGC(Zing Garbage Collector)。每种收集器有其特定的...

    Plumbr Handbook Java Garbage Collection

    这里提到的算法包括但不限于Serial GC、Parallel GC、Concurrent Mark Sweep (CMS) GC和Garbage First (G1) GC等。每种算法都有其特定的应用场景和优缺点,因此,了解这些算法的工作原理对于选择合适的垃圾收集策略...

    细述 Java垃圾回收机制→Types of Java Garbage Collectors 1

    4. G1(Garbage-First)Garbage Collector:G1是为大内存应用设计的,它将堆划分为多个区域,可以并行、增量地回收内存,同时最小化碎片。G1能够预测和控制垃圾回收停顿时间,适合大规模服务器应用。启用G1使用-XX:...

    The Java Garbage Collection Mini Book

    6. 多区域收集器:文档进一步介绍了如垃圾优先(Garbage-First,G1)、平衡(Balanced)、调时器(Metronome)以及C4和Shenandoah收集器等多区域收集器,这些收集器为大规模应用提供了不同的性能特征。 7. 堆结构:...

    Garbage Collection Algorithms For Automatic Dynamic Memory Management

    并发收集则是在应用程序运行的同时进行垃圾收集,减少了对应用性能的影响,例如Java的CMS(Concurrent Mark Sweep)和G1(Garbage-First)收集器。 6. **C#和.NET框架中的垃圾收集** .NET框架使用了自己的垃圾收集...

Global site tag (gtag.js) - Google Analytics