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

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.

主站蜘蛛池模板: 景洪市| 阿图什市| 交城县| 织金县| 扶沟县| 丹东市| 贵溪市| 大厂| 永修县| 青浦区| 隆尧县| 大方县| 宣化县| 即墨市| 师宗县| 蒙山县| 承德市| 资兴市| 康马县| 寿阳县| 石狮市| 广丰县| 楚雄市| 临武县| 郧西县| 天等县| 陆良县| 砚山县| 嘉黎县| 新安县| 微山县| 隆德县| 锡林浩特市| 扶绥县| 安陆市| 淳化县| 泾川县| 巴东县| 永新县| 龙陵县| 永登县|