I’ve read plenty of articles about tuning GC in Java and have often wondered how many people really use some of the more advanced features.
I’ve always avoided tuning where possible and concentrated on writing the simplest possible code I can (Brian Goetz’s advice) – this seems to have worked well for me so far.
Are these tuning strategies resilient to change across VM versions or do they require constant re-assessment?
The one tuning that I have made use of is the -server flag.
Part of my current job is the care and feeding of a large java application that was designed to run with a large amount of memory (currently around 8 Gb), mostly due to ongoing calculations with lots of cached data. I did the initial deployment with the standard GC setup , mostly because there wasn’t a simple way to simulate the production environment running at full tilt.
In stages, over the next few months, I’ve customized the GC settings. Generally, the biggest available knob seems to be adjusting the frequency and magnitude of incremental gc – the biggest improvement has been in trading off large periodic gc for smaller and more frequent ones. But we’ve definitely been able to see performance improvements.
I’m not going to post my specific settings because a) they’re specific to our setup, and b) because I don’t have them handy :). But in general, what I’ve found is
Here’s a good reference from a prev. stackoverflow discussion.