<html>
<head>
<meta content="text/html; charset=utf-8" http-equiv="Content-Type">
</head>
<body text="#000000" bgcolor="#FFFFFF">
<br>
Hi all,<br>
<br>
<div class="moz-cite-prefix">On 2015-12-20 23:43, charlie hunt
wrote:<br>
</div>
<blockquote
cite="mid:1D29F348-2D6C-4E68-A9F2-B43E1C7C4540@oracle.com"
type="cite">
<meta http-equiv="Content-Type" content="text/html; charset=utf-8">
Hi Fabian,
<div class=""><br class="">
</div>
<div class="">I’m glad you brought this discussion to
hotspot-gc-dev. This is a very good place to have this
discussion.</div>
<div class=""><br class="">
</div>
<div class="">If others on hotspot-gc-dev need a bit more context
of the thread of discussion, I’d be glad to do so.</div>
<div class=""><br class="">
</div>
<div class="">The gist of the issue is whether G1 should reduce
the size of eden space when MaxGCPauseMillis is exceeded.</div>
<div class=""><br class="">
</div>
<div class="">To pickup things on where this thread is going … </div>
<div class=""><br class="">
</div>
<div class="">If the workload is very reproducible, then is it
unreasonable to ask for a configuration run that enabled
ParallelRefProcEnabled with set of command line options that
were used in the first run? How about we exercise some good
practices here and change one configuration setting at a time?
And, let’s also ensure we have results that are reproducible.
We have several unanswered questions between the first and
second run, i.e. why did ref proc times drop so drastically, is
it all due to ParallelRefProcEnabled? How could a forced larger
Eden size allow Ref Proc times to be reduced? Is the workload
producing repeatable results / behavior?</div>
<div class=""><br class="">
</div>
<div class="">Aside from the specifics just mentioned, I think the
key thing to understand here is the school thought behind
shrinking the size of eden when GC pauses exceed
MaxGCPauseMillis, and why it is not a good idea to grow the size
of Eden in such a case? Perhaps one of the long time GC
engineers would like to join the fun? ;-)</div>
</blockquote>
<br>
I haven't read the other email thread, but just thought I could
answer this one question quickly.<br>
<br>
The reason for shrinking the young gen size when the pause time goal
is exceeded is simply that it is assumed that a larger young gen
takes longer to collect. Shrinking the young gen is then a natural
response when the pause times get too long.<br>
<br>
However, this is a very simplistic view of the world. As noted here,
it can sometimes be much better to grow the young gen size instead
of shrinking it. Growing the young gen will make GCs happen less
frequently and may allow more objects to die. And in reality the
collection time is related to the number of live objects, not the
young gen size itself. The problem is that it is very hard to know
if it is better to grow or shrink the young gen in the general case.<br>
<br>
Bengt<br>
<br>
<blockquote
cite="mid:1D29F348-2D6C-4E68-A9F2-B43E1C7C4540@oracle.com"
type="cite">
<div class=""><br class="">
</div>
<div class="">@Kirk: You mentioned, “reference processing times
clearly dominated resulting in Eden being shrunk in a feeble
attempt to meet the pause time goal”. Can you offer some
alternatives that would be a better alternative that G1 could do
adaptively to meet the pause time goal in the presence of high
reference processing times, and for bonus points, could you file
those enhancements in JIRA so they can be further evaluated and
vetted?</div>
<div class=""><br class="">
</div>
<div class="">thanks,</div>
<div class=""><br class="">
</div>
<div class="">charlie</div>
<div class=""><br class="">
<div class="">
<div class=""> <br class="">
<div>
<blockquote type="cite" class="">
<div class="">On Dec 20, 2015, at 1:48 PM, Fabian Lange
<<a moz-do-not-send="true"
href="mailto:fabian.lange@codecentric.de" class="">fabian.lange@codecentric.de</a>>
wrote:</div>
<br class="Apple-interchange-newline">
<div class="">
<div dir="ltr" class="">
<div class="gmail_extra">Hi Kirk,</div>
<div class="gmail_extra">I know that it is
questioned also on the other list, where I will
continue to discuss potential better settings, but
I can tell you that the workload is really
reproducible, as this system measures its data
ingress and the rate was close to equal. Data
egress was radically different.</div>
<div class="gmail_extra">My main concern here on
hotspot-gc-dev is that the defaults produced a bad
result. Plus I have the feeling the GC optimizes
in the wrong direction (shrinking eden instead of
increasing eden).</div>
<div class="gmail_extra">I will come back to this
list when we manually figured out good settings.</div>
<div class="gmail_extra"><br class="">
</div>
<div class="gmail_extra">Fabian<br class="">
<br class="">
<div class="gmail_quote">On Sun, Dec 20, 2015 at
7:38 PM, <a moz-do-not-send="true"
href="mailto:kirk@kodewerk.com" class="">kirk@kodewerk.com</a>
<span dir="ltr" class=""><<a
moz-do-not-send="true"
href="mailto:kirk@kodewerk.com"
target="_blank" class=""><a class="moz-txt-link-abbreviated" href="mailto:kirk@kodewerk.com">kirk@kodewerk.com</a></a>></span>
wrote:<br class="">
<blockquote class="gmail_quote" style="margin:0
0 0 .8ex;border-left:1px #ccc
solid;padding-left:1ex">
<div style="word-wrap:break-word" class="">Hi
Fabian,
<div class=""><br class="">
</div>
<div class="">I don’t think the
experimentation with your app is over. I
don’t think the differences between the
two runs can easily be dismissed as the
result of changing the values of a few
flags. In the first relatively short run,
reference processing times clearly
dominated resulting in Eden being shrunk
in a feeble attempt to meet the pause time
goal. I don’t think that the shrinkage in
reference processing time cannot be solely
attributed to turning on parallel
reference processing. It seems as if
something else changed. At any rate, I
believe you should relax the minimum Eden
size from 25%. I have posted a number of
charts which anyone should be able to see
@ <a moz-do-not-send="true"
href="https://drive.google.com/a/jclarity.com/file/d/0B6IuyTuhCQTPUGpFcDA4bF8zbUk/view?usp=sharing"
target="_blank" class="">https://drive.google.com/a/jclarity.com/file/d/0B6IuyTuhCQTPUGpFcDA4bF8zbUk/view?usp=sharing</a>.</div>
<div class=""><br class="">
</div>
<div class="">Regards,</div>
<div class="">Kirk</div>
<div class="">
<div class="h5">
<div class=""><br class="">
</div>
<div class=""><br class="">
<div class="">
<blockquote type="cite" class="">
<div class="">On Dec 20, 2015, at
1:27 PM, Fabian Lange <<a
moz-do-not-send="true"
href="mailto:fabian.lange@codecentric.de"
target="_blank" class=""><a class="moz-txt-link-abbreviated" href="mailto:fabian.lange@codecentric.de">fabian.lange@codecentric.de</a></a>>
wrote:</div>
<br class="">
<div class="">
<div dir="ltr" class="">
<div class="gmail_quote">
<div dir="ltr" class="">Hi,</div>
<div dir="ltr" class="">(originall
posted on
adoption-discuss)<br
class="">
<div class="">since a
while I have been
recommending and using
G1GC for JDK 8
applications.</div>
<div class=""><br class="">
</div>
<div class="">This week I
was looking at an
application which should
be the ideal candidate.</div>
<div class="">It was given
4GB ram, has a steady
memory usage of about
1-2GB and during its
work it generates only
garbage. It reads data
from sockets,
deserializes it,
manipulates it,
serializes it and writes
it out to sockets. It is
processing 100k to 500k
of such requests per
second.</div>
<div class=""><br class="">
</div>
<div class="">With the
default G1 settings the
machine was very loaded.
The collection times
were pretty long. It
even ran out of memory a
few times because the GC
could not catch up.</div>
<div class=""><br class="">
</div>
<div class="">When looking
at the logs I was
surprised to see
extremely small
eden/young sizes. The
old gen was really big
(like 3.5GB, but mostly
empty) while G1 was
churning on 300MB young.</div>
<div class=""><br class="">
</div>
<div class="">I raised the
question on <a
moz-do-not-send="true"
href="https://groups.google.com/a/jclarity.com/d/msg/friends/hsZiz6HTm9M/MbuttBioCgAJ"
target="_blank"
class=""><a class="moz-txt-link-freetext" href="https://groups.google.com/a/jclarity.com/d/msg/friends/hsZiz6HTm9M/MbuttBioCgAJ">https://groups.google.com/a/jclarity.com/d/msg/friends/hsZiz6HTm9M/MbuttBioCgAJ</a></a>
where Charlie Hunt was
so kind to explain the
reasons behind the
behaviour. It either did
not make sense to me, or
I did not understand the
explanation. </div>
<div class=""><br class="">
</div>
<div class="">What I did
is what I always did
regardless of the
collector: I increased
young space, knowing it
contains mostly garbage.</div>
<div class="">The overall
behaviour of the JVM was
much improved by that.</div>
<div class=""><br class="">
</div>
<div class="">I found it
irritating, that
according to Charlie,
the main reason for the
small eden is the Pause
Time Limit. Because GC
was not meeting its goal
it reduced eden. While I
observed better results
doing the opposite.</div>
<div class=""><br class="">
</div>
<div class="">I also
enabled -XX:+<span
style="font-family:Arial,Helvetica,sans-serif;font-size:13px"
class="">ParallelRefProcEnabled.</span></div>
<div class=""><span
style="font-family:Arial,Helvetica,sans-serif;font-size:13px"
class=""><br class="">
</span></div>
<div class=""><span
style="font-family:Arial,Helvetica,sans-serif;font-size:13px"
class="">Logs are
available from the
above discussion, but
I can send them in
separate mail if
desired.</span></div>
<div class=""><span
style="font-family:Arial,Helvetica,sans-serif;font-size:13px"
class=""><br class="">
</span></div>
<div class=""><font
class="" face="Arial,
Helvetica, sans-serif">As
far as I can tell the
ergonomics are not
working for me, and
the changes I need to
do are
counter intuitive.
From other discussions
I learned that quite
many people observed
better overall
performance with
raising the pause time
restriction.</font></div>
<div class=""><font
class="" face="Arial,
Helvetica, sans-serif"><br
class="">
</font></div>
<div class=""><font
class="" face="Arial,
Helvetica, sans-serif">Is
there public
information to why the
current defaults are
as they are? How would
feedback on these
defaults work?</font></div>
<div class=""><br class="">
</div>
<div class="">Best
regards,</div>
<div class="">Fabian</div>
</div>
</div>
<br class="">
</div>
</div>
</blockquote>
</div>
<br class="">
</div>
</div>
</div>
</div>
</blockquote>
</div>
<br class="">
</div>
</div>
</div>
</blockquote>
</div>
<br class="">
</div>
</div>
</div>
</blockquote>
<br>
</body>
</html>