我正在Kubernetes中运行一个容器化的Java应用程序。
为了使jvm保留根据容器规范的内存,-XX:+UnlockExperimentalVMOptions -XX:+UseCGroupMemoryLimitForHeap必须设置标志。
-XX:+UnlockExperimentalVMOptions -XX:+UseCGroupMemoryLimitForHeap
如果这两个标志与Xms和Xmx标志一起设置,那么jvm的行为是什么?一个标志会覆盖另一个标志吗?
例如,如果我们java -XX:+UnlockExperimentalVMOptions -XX:+UseCGroupMemoryLimitForHeap -Xms -Xms2500M -Xmx2500M -jar myjar.jar 在一个容器中的容器中将请求限制为4Gi,将响应限制为4Gi,则在具有128Gi内存的主机中,JVM将保留多少内存?
java -XX:+UnlockExperimentalVMOptions -XX:+UseCGroupMemoryLimitForHeap -Xms -Xms2500M -Xmx2500M -jar myjar.jar
-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/