G1:long remark pauses

Mikael Gerdin mikael.gerdin at oracle.com
Wed May 28 12:43:12 UTC 2014


On Wednesday 28 May 2014 07.20.59 charlie hunt wrote:
> Hi Thomas,
> 
> About the only thing I can suggest is running the concurrent cycle more
> frequently so as to run the remark more frequently.  Perhaps setting
> InitiatingHeapOccupancyPercent low enough that the concurrent cycle runs
> all the time.

If the weakly reachable objects are reasonably short-lived an increased 
survivor size and tenuring threshold could allow more weak references to be 
dealt with by incremental young collections instead.

/Mikael

> 
> The remark is showing good parallelism since User=25.82 and real=2.39.
> 
> I suppose a refactoring of the application to reduce usage of
> WeakReferences is another alternative.
> 
> Btw, does ParallelOld GC or CMS GC show a similar behavior with a high
> number of WeakReferences as a GC issue?
> 
> charlie
> 
> On 05/28/2014 02:29 AM, Thomas Viessmann wrote:
> > Hi Charlie and all,
> > 
> > you were pretty close. It's the weak references which stops the world,
> > not the SoftRefs:
> > 
> > 248766.241: [GC remark 248766.246: [GC ref-proc248766.246:
> > [SoftReference, 184918 refs, 0.1139337 secs]248766.360:
> > *[WeakReference, 2104678 refs, 1.9516481 secs]248768.312:*
> > [FinalReference, 45 refs, 0.0033450 secs]248768.315:
> > [PhantomReference, 106 refs, 0.0029866 secs]248768.318: [JNI Weak
> > Reference, 0.0008403 secs], 2.0846210 secs], 2.3878287 secs]
> > 
> >  [Times: user=25.82 sys=0.87, real=2.39 secs]
> > 
> > 248768.630: Total time for which application threads were stopped:
> > 2.4019674 seconds
> > 
> > There are also a lot of SoftRefs around but those are not the culprit.
> > Varying  -XX:SoftRefLRUPolicyMSPerMB between 100 and 10000 did not
> > change anything.
> > 
> > Any idea how this could be addressed?
> > 
> > Thanks and Regards
> > 
> > Thomas
> > 
> > On 05/16/14 14:40, charlie hunt wrote:
> >> From the sound of what Thomas is describing, this might be one of
> >> those apps that's making heavy use of SoftReferences. Output from
> >> -XX:+PrintReferenceGC as Bengt suggested will show if that's the case.
> >> 
> >> If we see a large number of SoftReferences being processed per GC, we
> >> may get further help with tuning the SoftReference reclamation
> >> policy, (-XX:SoftRefLRUPolicyMSPerMB).
> >> 
> >> charlie
> >> 
> >> On 05/16/2014 07:32 AM, Bengt Rutisson wrote:
> >>> Hi Thomas,
> >>> 
> >>> 
> >>> 16 maj 2014 kl. 14:01 skrev Thomas Viessmann
> >>> 
> >>> <thomas.viessmann at oracle.com <mailto:thomas.viessmann at oracle.com>>:
> >>>> Hi Bengt,
> >>>> 
> >>>> 
> >>>> Thanks for confirming. ParallelOld had stop pauses in the range of
> >>>> 20 to 30 seconds.
> >>>> CMS was a disaster due to extreme fragmentation and high promotion
> >>>> rate even with
> >>>> huge eden and survivors.
> >>> 
> >>> Ok, so even with the long remark pauses G1 is performing better than
> >>> the other GCs?
> >>> 
> >>>> There are definitely lots of references. I can find out
> >>>> details.
> >>> 
> >>> Thanks, it would be interesting to get this data.
> >>> 
> >>> Thanks,
> >>> Bengt
> >>> 
> >>>> Thanks and Regards
> >>>> 
> >>>> Thomas
> >>>> 
> >>>> On 05/16/14 13:53, Bengt Rutisson wrote:
> >>>>> Hi again Thomas,
> >>>>> 
> >>>>> On 2014-05-16 13:34, Thomas Viessmann wrote:
> >>>>>> Hi Bengt,
> >>>>>> 
> >>>>>> Sure, the application has lots of objects and references.
> >>>>>> Downsizing the application has been tried The heap size of 24 g is
> >>>>>> already at minimum. A  smaller heap gave OutOfmemory really quick.
> >>>>>> My question was more whether the remark phases could be optimized
> >>>>>> further. I assume this is not the case and we have reached the
> >>>>>> limitations
> >>>>>> of G1, right?
> >>>>> 
> >>>>> How many reference objects does the application use? Can you run
> >>>>> it with -XX:+PrintReferenceGC to see how many there are?
> >>>>> 
> >>>>> If there are a lot of them I don't think there is much more that
> >>>>> can be done for the remark phase. But if there are not that many I
> >>>>> guess it means that the remark phase is inefficient.
> >>>>> 
> >>>>> Have you tried any of the other GCs? How do they behave with this
> >>>>> application?
> >>>>> 
> >>>>> Thanks,
> >>>>> Bengt
> >>>>> 
> >>>>>> Thanks and Regards
> >>>>>> 
> >>>>>> Thomas
> >>>>>> 
> >>>>>> On 05/16/14 13:18, Bengt Rutisson wrote:
> >>>>>>> Hi Thomas,
> >>>>>>> 
> >>>>>>> On 2014-05-16 13:10, Thomas Viessmann wrote:
> >>>>>>>> Hi Bengt,
> >>>>>>>> 
> >>>>>>>> Well, that's already done and it did improve things.
> >>>>>>>> argv[21]: -XX:+ParallelRefProcEnabled
> >>>>>>>> argv[22]: -XX:ParallelGCThreads=48
> >>>>>>> 
> >>>>>>> Sorry, I missed that.
> >>>>>>> 
> >>>>>>>> before -XX:+ParallelRefProcEnabled was set the stop times were in
> >>>>>>>> the range of 20 to 60 seconds.>>>>>>> 
> >>>>>>> OK. Glad it helped some. :)
> >>>>>>> 
> >>>>>>>> The application is a Cacao by Oracle. So they cannot change it.
> >>>>>>> 
> >>>>>>> Is there some way of reducing the amount of reference objects
> >>>>>>> that Cacao uses? Does it have cache sizes or similar that can be
> >>>>>>> tuned. With a JFR recording we might be able to figure out where
> >>>>>>> the reference objects come from.
> >>>>>>> 
> >>>>>>> Thanks,
> >>>>>>> Bengt
> >>>>>>> 
> >>>>>>>> Thanks and Regards
> >>>>>>>> 
> >>>>>>>> Thomas
> >>>>>>>> 
> >>>>>>>> On 05/16/14 12:58, Bengt Rutisson wrote:
> >>>>>>>>> Hi Thomas,
> >>>>>>>>> 
> >>>>>>>>> It looks like the application is using a lot of Reference
> >>>>>>>>> objects. The time spent in remark is dominated by reference
> >>>>>>>>> processing. See the attached graph generated from the log file
> >>>>>>>>> you sent.
> >>>>>>>>> 
> >>>>>>>>> You can try to see if adding -XX:+ParallelRefProcEnabled
> >>>>>>>>> improves the situation.
> >>>>>>>>> 
> >>>>>>>>> If the customer is interested in updating their application
> >>>>>>>>> they might want to see if they can reduce the number of
> >>>>>>>>> java.lang.ref.Reference objects they use.
> >>>>>>>>> 
> >>>>>>>>> Hths,
> >>>>>>>>> Bengt
> >>>>>>>>> 
> >>>>>>>>> On 2014-05-16 10:26, Thomas Viessmann wrote:
> >>>>>>>>>> Hi,
> >>>>>>>>>> 
> >>>>>>>>>> 
> >>>>>>>>>> I've been tuning a Java 7u51, Solaris 10, T4 system with 24G
> >>>>>>>>>> heap.
> >>>>>>>>>> My customer is not very happy with the remark pauses of  up
> >>>>>>>>>> to 2 seconds.
> >>>>>>>>>> 
> >>>>>>>>>>  -XX:ParallelGCThreads=48 turned out to be the optimum. Here
> >>>>>>>>>> 
> >>>>>>>>>> is the log file
> >>>>>>>>>> which contains the java args at the top:
> >>>>>>>>>> 
> >>>>>>>>>> http://aubing.de.oracle.com/gclog/gc_log_03052014.log
> >>>>>>>>>> 
> >>>>>>>>>> Any idea to drive the remark stop times further down?
> >>>>>>>>>> 
> >>>>>>>>>> 
> >>>>>>>>>> Thanks and Regards
> >>>>>>>>>> 
> >>>>>>>>>> Thomas
> >>>>>>>> 
> >>>>>>>> ORACLE Deutschland B.V. & Co. KG | Riesstr.25 | D-80992 Muenchen
> >>>>>>>> 
> >>>>>>>> ORACLE Deutschland B.V. & Co. KG
> >>>>>>>> Hauptverwaltung: Riesstr. 25, D-80992 Muenchen
> >>>>>>>> Registergericht: Amtsgericht Muenchen, HRA 95603
> >>>>>>>> Geschäftsführere: Juergen Kunz
> >>>>>>>> 
> >>>>>>>> Komplementärin: ORACLE Deutschland Verwaltung B.V.
> >>>>>>>> Hertogswetering 163/167, 3543 AS Utrecht, Niederlande
> >>>>>>>> Handelsregister der Handelskammer Midden-Niederlande, Nr. 30143697
> >>>>>>>> Geschäftsführer: Alexander van der Ven, Astrid Kepper, Val Maher
> >>>>>>>> 
> >>>>>>>> -------------------------------------------------------------------
> >>>>>>>> -----
> >>>>>>>> -------------------------------------------------------------------
> >>>>>>>> -----
> >>>>>>>> <mime-attachment.gif> <http://www.oracle.com/commitment> Oracle
> >>>>>>>> is committed to developing practices and products that help
> >>>>>>>> protect the environment
> >>>>>> 
> >>>>>> ORACLE Deutschland B.V. & Co. KG | Riesstr.25 | D-80992 Muenchen
> >>>>>> 
> >>>>>> ORACLE Deutschland B.V. & Co. KG
> >>>>>> Hauptverwaltung: Riesstr. 25, D-80992 Muenchen
> >>>>>> Registergericht: Amtsgericht Muenchen, HRA 95603
> >>>>>> Geschäftsführere: Juergen Kunz
> >>>>>> 
> >>>>>> Komplementärin: ORACLE Deutschland Verwaltung B.V.
> >>>>>> Hertogswetering 163/167, 3543 AS Utrecht, Niederlande
> >>>>>> Handelsregister der Handelskammer Midden-Niederlande, Nr. 30143697
> >>>>>> Geschäftsführer: Alexander van der Ven, Astrid Kepper, Val Maher
> >>>>>> 
> >>>>>> ---------------------------------------------------------------------
> >>>>>> ---
> >>>>>> ---------------------------------------------------------------------
> >>>>>> ---
> >>>>>> <mime-attachment.gif> <http://www.oracle.com/commitment> Oracle
> >>>>>> is committed to developing practices and products that help
> >>>>>> protect the environment
> >>>> 
> >>>> ORACLE Deutschland B.V. & Co. KG | Riesstr.25 | D-80992 Muenchen
> >>>> 
> >>>> ORACLE Deutschland B.V. & Co. KG
> >>>> Hauptverwaltung: Riesstr. 25, D-80992 Muenchen
> >>>> Registergericht: Amtsgericht Muenchen, HRA 95603
> >>>> Geschäftsführere: Juergen Kunz
> >>>> 
> >>>> Komplementärin: ORACLE Deutschland Verwaltung B.V.
> >>>> Hertogswetering 163/167, 3543 AS Utrecht, Niederlande
> >>>> Handelsregister der Handelskammer Midden-Niederlande, Nr. 30143697
> >>>> Geschäftsführer: Alexander van der Ven, Astrid Kepper, Val Maher
> >>>> 
> >>>> -----------------------------------------------------------------------
> >>>> -
> >>>> -----------------------------------------------------------------------
> >>>> -
> >>>> <green-for-email-sig_0.gif> <http://www.oracle.com/commitment>
> >>>> Oracle is committed to developing practices and products that help
> >>>> protect the environment
> > 
> > ORACLE Deutschland B.V. & Co. KG | Riesstr.25 | D-80992 Muenchen
> > 
> > ORACLE Deutschland B.V. & Co. KG
> > Hauptverwaltung: Riesstr. 25, D-80992 Muenchen
> > Registergericht: Amtsgericht Muenchen, HRA 95603
> > Geschäftsführere: Juergen Kunz
> > 
> > Komplementärin: ORACLE Deutschland Verwaltung B.V.
> > Hertogswetering 163/167, 3543 AS Utrecht, Niederlande
> > Handelsregister der Handelskammer Midden-Niederlande, Nr. 30143697
> > Geschäftsführer: Alexander van der Ven, Astrid Kepper, Val Maher
> > 
> > ------------------------------------------------------------------------
> > ------------------------------------------------------------------------
> > Green Oracle <http://www.oracle.com/commitment> Oracle is committed to
> > developing practices and products that help protect the environment




More information about the hotspot-gc-dev mailing list