heap memory usage increasing over time with a fixed live set size
Aleksey Shipilev
shade at redhat.com
Mon Nov 4 08:37:10 UTC 2019
On 11/3/19 8:43 AM, Amir Hadadi wrote:
> Once concurrent class unloading is incorporated, when will it be triggered?
The same way it is triggered now with -XX:+ClassUnloadingWithConcurrentMark.
> Evidently running it only on special occasions (e.g. degenerated gc) can become a nasty performance
> race to the bottom for certain workloads.
Yes, and it is a tricky tradeoff between long-term stability in corner cases (when class unloading
is needed to purge f.ex. string table) and latency overheads over all common cases (where class
unloading needs to do somewhat heavy stuff during final mark pause). Both cases suck in their own way.
> Will it be triggered as if -XX:+ClassUnloadingWithConcurrentMark was enabled, making this flag a no op?
> What are the plans in that respect?
The plan is to make class unloading concurrent and always enabled. There is a working version in our
sh/jdk staging repo:
https://hg.openjdk.java.net/shenandoah/jdk
https://builds.shipilev.net/openjdk-shenandoah-jdk/
--
Thanks,
-Aleksey
More information about the shenandoah-dev
mailing list