High termination times pre-concurrent cycle in G1
Thomas Schatzl
thomas.schatzl at oracle.com
Mon Sep 5 10:45:14 UTC 2016
Hi William,
On Mon, 2016-09-05 at 12:02 +0200, William Good wrote:
> Hi Thomas,
>
> Attached is a log file from a run with this morning's tip. I don't
> see any change unfortunately.
hmm. I talked to somebody else about it, and looked a bit at the Akka
code for this and related bugs: the reason why it does not help may
just be because the problem is the data structure itself, not the gc.
I.e. the AbstractNodeQueue from Akka seems to be a linked list of
nodes, probably rather very deep and with low fan-out. So there may be
not a lot of work that can actually be done in parallel.
Additionally, the references into young gen really cause significant
work.
As opposed to the case that JDK-8152438 fixes, that is, if a worker
thread does have a lot of work that could be taken over by other
threads available, but does not share it.
If that is indeed the case, jdk9 will not help a lot if anything. If I
look at another referenced bug [1], AbstractNodeQueue seems kind of a
"textbook" linked list.
Fixing the application seems to be the easiest option here.
Thanks for your effort in pinning this down,
Thomas
[1] https://github.com/akka/akka/issues/17547
> I'll try with jdk9 tip later today since you mention there are more
> fixes there.
>
> configure summary looked like this, I think everything here is in
> order:
>
> Configuration summary:
> * Debug level: release
> * JDK variant: normal
> * JVM variants: server
> * OpenJDK target: OS: linux, CPU architecture: x86, address length:
> 64
>
> Tools summary:
> * Boot JDK: java version "1.8.0_101" Java(TM) SE Runtime
> Environment (build 1.8.0_101-b13) Java HotSpot(TM) 64-Bit Server VM
> (build 25.101-b13, mixed mode) (at /var/tmp/jdk1.8.0_101)
> * C Compiler: gcc (GCC) 4.8.5 20150623 (Red Hat-4) version 4.8.5
> (at /usr/bin/gcc)
> * C++ Compiler: g++ (GCC) 4.8.5 20150623 (Red Hat-4) version 4.8.5
> (at /usr/bin/g++)
Yes, that's fine.
Thanks,
Thomas
More information about the hotspot-gc-use
mailing list