说明新的JVM内存参数的含义InitialRAMPercentage和MinRAMPercentage

时间:2019-01-21 14:41:00

标签: java docker jvm

参考:https://bugs.java.com/bugdatabase/view_bug.do?bug_id=8186315

我真的很难找出MinRAMPercentage的功能,尤其是与InitialRAMPercentage相比。

我假设InitialRAMPercentage设置了启动时的堆数量,MinRAMPercentage和MaxRAMPercentage设置了允许JVM收缩/增长到的堆的上下限。

显然不是这样。当我启动JVM(使用UseContainerSupport,具有这些新的内存设置参数)时,如下所示:

java -XX:+UseContainerSupport -XX:InitialRAMPercentage=40.0 -XX:MinRAMPercentage=20.0 -XX:MaxRAMPercentage=80.0 -XX:+PrintFlagsFinal -version | grep Heap

设置了InitialHeap和MaxHeap,我找不到“最小堆大小”值;因此,该MinRAMPercentage似乎永远不会被使用。

超级困惑,显然,我不是唯一的一个。正如我收集的herehere一样,OpenJ9帅哥似乎也没有完全解析这些选项的意图。他们似乎选择不实施MinRAMPercentage afaics。

那么:设置MinRAMPercentage的实际用途和效果是什么?

1 个答案:

答案 0 :(得分:12)

-XX:InitialRAMPercentage用于calculate initial heap size,而未设置InitialHeapSize / -Xms

这听起来违反直觉,但是当未设置-XX:MaxRAMPercentage / -XX:MinRAMPercentage时,MaxHeapSize-Xmx都用于计算最大堆大小

  • 对于物理内存较小的系统,MaxHeapSize估计为

    phys_mem * MinRAMPercentage / 100  (if this value is less than 96M)
    
  • 否则(非小物理内存)MaxHeapSize估计为

    MAX(phys_mem * MaxRAMPercentage / 100, 96M)
    

The exact formula有点复杂,因为它还考虑了其​​他因素。

注意:用于计算初始堆大小和最大堆大小的算法取决于特定的JVM版本。控制堆大小的首选方法是显式设置XmxXms

另请参阅this question