Why doesn't G1 start a marking cycle when the InitiatingHeapOccupancyPercent is achieved?

后端 未结 1 1661
佛祖请我去吃肉
佛祖请我去吃肉 2021-02-05 15:22

According to the documentation, XX:InitiatingHeapOccupancyPercent

Sets the Java heap occupancy threshold that triggers a marking cycle. Th

1条回答
  •  一个人的身影
    2021-02-05 15:45

    JDK-6976060 suggests that the need for a marking cycle is calculated at the end of a young GC. Depending on whether it uses the occupancy stats before or after the young GC this may or may not mean that eden space is always considered as 0% occupied for the purpose of IHOP calculation. With a 45% eden size that would mean 70% occupancy could never be reached, the maximum possible occupancy would be 55% and at that point the heap would be completely full and it would be too late for a mixed collection.

    But I am doubtful whether this is truly the case because in the face of dynamic young generation sizing this would make the documentation misleading and IHOP tuning far more difficult. It should be fairly easy to verify this with an artificial test-case and manually sized generations.

    If that's not the issue then GC pause (GCLocker Initiated GC) (young) might point to bug 8140597, which is fixed in jdk9b94.


    Update: The description in Bug 8151176 indeed suggests that for the purpose of the IHO-percentage calculation it calculates oldgen occupancy/overall heap size. Which means young generation occupancy is completely ignored, which in turn means if young gen fraction > IHOP then it can never initiate a concurrent cycle.

    The reason is that static IHOP starts if old gen occupancy exceeds a fixed percentage of the current heap capacity. If either the user or ergonomics decide that the old gen can not be larger than that fraction of the heap capacity that triggers concurrent mark, marking will never start.

    So currently available solutions are

    • constrain the young gen fraction < IHOP
    • decrease IHOP to take the minimum possible old gen fraction into account
    • let the JVM adjust the IHOP dynamically

    Update2: The latest comment on that bug indicates that this has been fixed for some time, so this answer should be considered as historic.

    0 讨论(0)
提交回复
热议问题