Currently in our testing environment the max and min JVM heap size are set to the same value, basically as much as the dedicated server machine will allow for our application. Is this the best configuration for performance or would giving the JVM a range be better?
Setting -Xms and -Xmx to the same value increases predictability by removing the most important sizing decision from the virtual machine. However, the virtual machine is then unable to compensate if you make a poor choice.
Set the initial and maximum heap sizes to 4096 to start tuning, because 64-bit operating systems have an address space limit of 4 GB, regardless of the amount of physical memory in the system. Never set the JVM heap size larger than the physical memory in the system.
Maximum heap size is 1/4th of the computer's physical memory or 1 GB (whichever is smaller) by default. The maximum heap size can be overridden using -Xmx.
A too small heap size may affect performance if your system also does not have enough cores, so that the garbage collectors do compete over the CPU with the business threads. At some point, the CPU spends a significant time on garbage collection.
Peter 's answer is correct in that -Xms
is allocated at startup and it will grow up to -Xmx
(max heap size) but it's a little misleading in how he has worded his answer. (Sorry Peter I know you know this stuff cold).
Setting ms == mx effectively turns off this behavior. While this used to be a good idea in older JVMs, it is no longer the case. Growing and shrinking the heap allows the JVM to adapt to increases in pressure on memory yet reduce pause time by shrinking the heap when memory pressure is reduced. Sometimes this behavior doesn't give you the performance benefits you'd expect and in those cases it's best to set mx == ms. OOME is thrown when heap is more than 98%
of time is spent collecting and the collections cannot recover more than 2%
of that. If you are not at max heaps size then the JVM will simply grow so that you're beyond that boundaries. You cannot have an OutOfMemoryError
on startup unless your heap hits the max heap size and meets the other conditions that define an OutOfMemoryError
.
For the comments that have come in since I posted. I don't know what the JMonitor blog entry is showing but this is from the PSYoung
collector.
size_t desired_size = MAX2(MIN2(eden_plus_survivors, gen_size_limit()), min_gen_size());
I could do more digging about but I'd bet I'd find code that serves the same purpose in the ParNew
and PSOldGen
and CMS Tenured
implementations. In fact it's unlikely that CMS would be able to return memory unless there has been a Concurrent Mode Failure
. In the case of a CMF
the serial collector will run and that should include a compaction after which top of heap would most likely be clean and therefore eligible to be deallocated.
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With