2017-02-13T13:08:44.032+0800: 70058.910: [GC (Allocation Failure) 2017-02-13T13:08:44.033+0800: 70058.910: [ParNew: 5565156K->90568K(5662336K), 0.1661369 secs] 8129600K->3164530K(13002368K), 0.1663049 secs] [Times: user=0.61 sys=0.00, real=0.16 secs]
年轻代垃圾回收。年轻代的容量为5662336K,通过本次回收,年轻代使用量从5565156K降到了90568K,共耗时0.1661369秒;整个堆容量为13002368K,堆的使用量从8129600K降到了3164530K,共耗时0.1663049秒
2017-02-13T13:08:44.204+0800: 70059.081: [GC (CMS Initial Mark) [1 CMS-initial-mark: 3073961K(7340032K)] 3178414K(13002368K), 0.0105904 secs] [Times: user=0.02 sys=0.00, real=0.01 secs]
CMS初始化标记阶段(需要stop the world),这个阶段标记的是由根(root)可直达的对象(也就是root之下第一层对象),标记期间整个应用线程会停止。老年代容量为7340032K,在使用了3073961K时触发了该标记操作;整个堆容量为13002368K,在使用了3178414K时触发了改标记,共耗时0.0105904秒
说明:
2017-02-13T13:08:44.214+0800: 70059.092: [CMS-concurrent-mark-start]
开始并发标记阶段,之前被停止的应用线程会重新启动;从初始化阶段标记的所有可达的对象(root之下第一层队形)出发标记处第一层对象所引用的对象(root之下第二层、三层等等)
2017-02-13T13:08:46.076+0800: 70060.954: [CMS-concurrent-mark: 1.861/1.861 secs] [Times: user=2.45 sys=0.01, real=1.86 secs]
并发标记总共花费1.861秒cpu时间和1.861秒时钟时间(人可感知的时间)
说明:
wall time解释:
又叫wall-clock time, wiki解释为:Wall-clock time is the time that a clock on the wall (or a stopwatch in hand) would measure as having elapsed between the start of the process and "now".
2017-02-13T13:08:46.076+0800: 70060.954: [CMS-concurrent-preclean-start]
并发预清理开始。预清理也属于并发处理阶段。这个阶段主要并发查找在做并发标记阶段时从年轻代晋升到老年代的对象或老年代新分配的对象(大对象直接进入老年代)或发生变化的线程(mutators)更新的对象,来减少重新标记阶段的工作量
说明:
关于mutators的概念,参考Advanced Design and Implementation of Virtual Machines解释如下:
5.5小节中解释: In GC community, the application threads are usually called mutators, since they mutate the heap. e threads conducting garbage collection are called collectors, since they recycle the heap. Note mutators and collectors are not necessarily separate threads. One thread can shi its role between mutator and collector. 6.8小节中解释如下: With stop-the-world GC, the mutators are suspended for garbage collection, then the collection can be done in the context of the suspended mutators. In this design, collectors and mutators are the same native threads in di erent phases.
2017-02-13T13:08:46.098+0800: 70060.976: [CMS-concurrent-preclean: 0.022/0.022 secs] [Times: user=0.02 sys=0.00, real=0.02 secs]
并发预清理阶段花费0.022秒cpu时间和0.022秒时钟时间
2017-02-13T13:08:46.098+0800: 70060.976: [CMS-concurrent-abortable-preclean-start]
CMS: abort preclean due to time 2017-02-13T13:08:51.240+0800: 70066.117: [CMS-concurrent-abortable-preclean: 2.939/5.142 secs] [Times: user=3.27 sys=0.00, real=5.14 secs]
可终止的并发预清理。总共花费2.939秒cpu时间和5.142秒时钟时间
2017-02-13T13:08:51.240+0800: 70066.118: [GC (CMS Final Remark) [YG occupancy: 213456 K (5662336 K)]2017-02-13T13:08:51.240+0800: 70066.118: [Rescan (parallel) , 0.0255997 secs]2017-02-13T13:08:51.266+0800: 70066.144: [weak refs processing, 0.0004628 secs]2017-02-13T13:08:51.266+0800: 70066.144: [class unloading, 0.0156084 secs]2017-02-13T13:08:51.282+0800: 70066.160: [scrub symbol table, 0.0033741 secs]2017-02-13T13:08:51.285+0800: 70066.163: [scrub string table, 0.0008130 secs][1 CMS-remark: 3073961K(7340032K)] 3287418K(13002368K), 0.0463703 secs] [Times: user=0.08 sys=0.00, real=0.05 secs]
重新标记阶段,会发生stop the world。最后标记老年代所有存活对象(包括在并发阶段创建或修改的对象),因为之前的并发标记和并发预清理阶段都是和应用线程并发进行的,所以可能有遗漏对象,这个阶段会保证标记到所有对象。
[YG occupancy: 213456 K (5662336 K)]:年轻代大小为5662336K,当前使用了213456 K
[Rescan (parallel) , 0.0255997 secs]:在应用暂停后重新并发标记所有存活对象,总共耗时0.0255997秒
[weak refs processing, 0.0004628 secs]:子阶段1---处理弱引用,共耗时0.0004628秒
[class unloading, 0.0156084 secs]:子阶段2---卸载已不使用的类,共耗时0.0156084秒
[scrub symbol table, 0.0033741 secs]:子阶段3--清理symbol table
[scrub string table, 0.0008130 secs]:子阶段4---清理string table
[1 CMS-remark: 3073961K(7340032K)] 3287418K(13002368K), 0.0463703 secs]:重新标记,老年代占用3073961K,总容量7340032K;整个堆占用3287418K,总容量13002368K。共耗时0.0463703秒
2017-02-13T13:08:51.287+0800: 70066.165: [CMS-concurrent-sweep-start]
开始并发清理所有未标记或已终结的对象
2017-02-13T13:08:51.988+0800: 70066.866: [CMS-concurrent-sweep: 0.702/0.702 secs] [Times: user=0.71 sys=0.00, real=0.70 secs]
并发清理总共耗时0.702秒cpu时间和0.702秒时钟时间
2017-02-13T13:08:51.989+0800: 70066.866: [CMS-concurrent-reset-start]
开始并发重置CMS算法内部数据,来未下次垃圾回收做准备
2017-02-13T13:08:52.006+0800: 70066.884: [CMS-concurrent-reset: 0.017/0.017 secs] [Times: user=0.02 sys=0.00, real=0.02 secs]
并发重置总共耗时0.017秒cpu时间/0.017秒时钟时间
参考:
https://blogs.oracle.com/poonam/entry/understanding_cms_gc_logs
https://plumbr.eu/handbook/garbage-collection-algorithms-implementations/concurrent-mark-and-sweep
http://www.oracle.com/technetwork/tutorials/tutorials-1876574.html
http://www.oracle.com/technetwork/articles/java/vmoptions-jsp-140102.html
相关推荐
Java虚拟机(JVM)是Java程序运行的基础,它的核心组成部分之一就是垃圾回收(Garbage Collection,简称GC)。GC机制负责自动管理Java内存,避免程序员手动处理内存分配和释放,从而减少内存泄漏和程序崩溃的风险。...
《JVM、GC详解及调优》是一份深入解析Java虚拟机(JVM)和垃圾收集(Garbage Collection,简称GC)的详细资料。本文将根据提供的信息,深入阐述JVM的工作原理,GC的机制以及如何进行JVM的性能调优。 首先,JVM是...
- **-verbose:gc-Xloggc:/logs/gc.log**: 开启垃圾回收日志记录,并指定日志文件的位置。 - **-XX:+UnlockExperimentalVMOptions-XX:+UseG1GC**: 启用G1垃圾回收器。 - **-XX:MaxGCPauseMillis=50**: 设置GC最大停顿...
CMS(Concurrent Mark Sweep)收集器,全称为"Mostly Concurrent Mark and Sweep Garbage Collector",是Java虚拟机(JVM)中一种旨在减少老年代(Old Generation)垃圾回收时停顿时间的并发垃圾收集器。它采用了...
Java垃圾收集是自动管理内存的过程,它负责回收不再使用的对象,防止内存泄漏。Java GC主要包括新生代、老年代和永久代(Java 8后变为元空间)的管理。 1. 新生代GC(Minor GC) 主要针对新生代的对象,使用复制...
5. **监控和调试**:启用详细的垃圾回收日志 (`-XX:+PrintGCDetails`, `-XX:+PrintGCTimeStamps`, `-XX:+PrintHeapAtGC`),并指定日志文件位置 (`-Xloggc:log/gc.log`),以便于后续的性能分析和调优。 #### 四、...
《垃圾回收机制详解》 垃圾回收(Garbage Collection, 简称GC)是Java虚拟机(JVM)管理内存的重要机制,它自动回收不再使用的对象以释放内存资源,防止内存泄露。本文将深入探讨垃圾回收的基本概念、常用策略、...
不同的JVM实现(如Oracle HotSpot JVM)提供了多种垃圾回收器,如Serial、Parallel、CMS、G1、ZGC等。选择合适的垃圾回收器需要根据应用的特性(如响应时间、内存大小、并发需求等)进行权衡。优化GC通常包括调整堆...
4. **垃圾收集**:JVM提供了多种GC算法,如Serial、ParNew、Parallel Scavenge、CMS、G1和ZGC等,它们各有优缺点,适用于不同场景。 **GC详解** 1. **GC目标**:GC的主要目标是高效地回收内存,减少停顿时间,并...
为了优化 SUN JVM 的性能,开发者可以调整各种参数,例如设置堆大小、启用或禁用特定的垃圾回收算法等。这些参数可以通过命令行选项传递给 JVM。 ##### 2.5 JVM 简单理解 - **Java 栈**:用于存储线程级别的局部...
本文将深入探讨JVM管理手册中的关键知识点,包括内存管理、垃圾回收机制以及JVM调优。 首先,我们需要理解JVM内存结构。在JVM中,内存被划分为几个主要区域,包括堆(Heap)、栈(Stack)、方法区(Method Area)、...
- 使用-XX:+PrintGCDetails和-XX:+PrintGCDateStamps等参数获取垃圾回收的详细日志,进一步分析性能瓶颈所在。 #### 六、调优步骤 - **Step 1:获取活跃数据**:通过GC日志获取活跃数据,使用-XX:+PrintGCDetails...
关于JVM的垃圾收集,课程会详细讲解不同的垃圾收集器,如Serial、ParNew、Parallel Scavenge、CMS、G1以及ZGC等,分析各自的优缺点以及适用场景。同时,也会探讨新生代与老年代的垃圾回收策略,如复制算法、标记-...
- **垃圾收集器介绍**:JVM提供了多种垃圾收集器,包括Serial Collector、Parallel Collector、CMS Collector以及G1 Collector等,每种收集器都有其适用场景和特点。 - **G1垃圾收集器详解**:G1(Garbage First)是一...
在Java开发领域,JVM(Java Virtual Machine)是至关重要的组成部分,它负责执行Java程序,并管理内存、类加载、垃圾回收等核心功能。对于Java开发者,尤其是面试阶段,深入理解JVM的工作原理和优化技巧是必不可少的...
- **垃圾回收**:JVM采用多种算法来进行垃圾回收,包括标记-清除、复制、标记-整理等。通过合理配置垃圾收集器,可以有效减少GC停顿时间,提高应用性能。 #### 4. 类卸载机制 当一个类不再被引用时,JVM可以对其...
**CMS垃圾回收器(Concurrent Mark Sweep):** 一种以获取最短回收停顿时间为目标的收集器。适用于对响应时间敏感的应用场合。 **新生代垃圾回收器和老年代垃圾回收器的区别:** - **新生代垃圾回收器:** 如Serial、...
- 输出详细的垃圾回收日志。 - 有助于分析垃圾回收行为和性能瓶颈。 - 通常在调优过程中使用。 7. **-XX:+HeapDumpOnOutOfMemoryError** - 当发生内存溢出错误时,自动生成堆转储文件。 - 有助于诊断内存泄漏...
同时,HotSpot JVM还支持CMS(Concurrent Mark Sweep)收集器,可以在不影响应用的情况下执行垃圾回收。 - **JRockit堆区**:JRockit是Oracle提供的另一种JVM实现,它的堆区设计更加灵活,可以根据应用程序的需求...