官术网_书友最值得收藏!

Understanding G1 GC logs

In this section, we will have a look at the G1 GC logs in detail.

The following features are marked in the following screenshot:

  1. Each heap region is of the size, 1M.
  2. The JVM is using G1 as its GC.
  3. The G1 collector starts a young collection 0.309 seconds after starting the application execution.
  4. The G1 collector uses multiple threads for the young collection.

 

  1. The G1 collector moves live objects from 14 Eden regions to 2 Survivor regions:

Let's examine another section of the same GC log, as follows:

The logs in the preceding screenshot are part of the same GC collection (note GC (5) in the logs). It shows logs from another young collection by the G1 GC. I've highlighted the Eden, Survivor, Old, and Humongous regions that the collector worked on. The values on the left side of the arrows show the counts of regions before the collection, and the values on the right are the counts of regions after the GC.

Let's examine the last section of the G1 log before the JVM quits with OutOfMemoryError, as follows:

  1. The collection uses multiple threads for the full collection.
  2. Full GC starts.
  3. Full GC includes a multiple number of steps, including marking live objects, preparing for compaction, adjusting pointers, and compacting the heap.
  4. As you will notice, there are no more Eden regions and Survivor regions available for allocation and compaction (0 -> 0). The Old and Humongous regions contain live objects that can't be collected. As a result, the JVM shuts down with OutOfMemoryError.
  5. This information logs the actual time taken by the full GC:

The bottom of the preceding screenshot includes a few final statistics, including total heap size, used heap size, region size, and more.

主站蜘蛛池模板: 五河县| 遵义市| 项城市| 万宁市| 固原市| 济南市| 武定县| 碌曲县| 出国| 新丰县| 万年县| 武穴市| 邯郸市| 凤山市| 唐山市| 南京市| 枝江市| 蒙自县| 图木舒克市| 邵东县| 昭平县| 威远县| 扶绥县| 乌兰察布市| 盐亭县| 读书| 碌曲县| 长沙市| 河池市| 南昌市| 进贤县| 内丘县| 江油市| 丹东市| 丽江市| 齐齐哈尔市| 扶余县| 上林县| 镇赉县| 鄄城县| 隆安县|