Java标志Xms和Xmx是否覆盖标志XX:+ UseCGroupMemoryLimitForHeap?

时间:2018-09-28 12:11:18

标签: java docker kubernetes containers flags

我正在Kubernetes中运行一个容器化的Java应用程序。

为了根据容器规范制作jvm保留内存,必须设置标志-XX:+UnlockExperimentalVMOptions -XX:+UseCGroupMemoryLimitForHeap

如果这两个标志与Xms和Xmx标志一起设置,那么jvm的行为是什么?一个标志会覆盖另一个标志吗?

例如,如果我们有java -XX:+UnlockExperimentalVMOptions -XX:+UseCGroupMemoryLimitForHeap -Xms -Xms2500M -Xmx2500M -jar myjar.jar 在具有容器的容器中,请求的限制为4Gi,响应的限制为4Gi;在具有128Gi内存的主机中,JVM将保留多少内存?

2 个答案:

答案 0 :(得分:2)

以这种方式考虑,在添加了UseCGroupMemoryLimitForHeap之前,您可以指定Xmx,其值要大于pod的值(只能在主机内存,而不是Pod本身),最终被杀死。默认情况下,如果未指定,则为内存的1/4。发生这种情况是因为堆的计算方式如下:

heap = memory / MaxRAMFraction

正在运行:

java -XX:+PrintFlagsFinal | grep MaxRAMFraction

将显示MaxRAMFraction = 4

现在添加了UseCGroupMemoryLimitForHeap,您可以知道从容器中取出了本身。默认情况下,它仍然是1/4;但是您当然可以通过MaxRAMFraction进行调整。

如果您同时指定两个参数,则Xms将获胜。总是。并且1)这是很合理的逻辑(因为UseCGroupMemoryLimitForHeapXmx更具体)2)这一点已经由我的实验完全证明了。不论指定顺序如何,Xmx总是获胜。

答案 1 :(得分:1)

-Xmx标志将覆盖-XX:+ UseCGroupMemoryLimitForHeap标志。

标志-XX:+ UseCGroupMemoryLimitForHeap使JVM可以检测容器中的最大堆大小。

-Xmx标志将最大堆大小设置为固定大小。

为回答您的示例,JVM将保留2500M堆空间。对于非堆和jvm的东西,还会有一些额外的内存使用情况。

要进一步调整容器中的内存使用量,可以使用-XX:MaxRAMFraction标志。 请参阅这篇文章:https://blog.csanchez.org/2017/05/31/running-a-jvm-in-a-container-without-getting-killed/