为什么在容器中的JVM还会OOM,不是说容器是可以自动扩缩容的嘛
容器确实提供了自动扩缩容的能力,但这种能力主要是指容器可以在运行时根据工作负载的变化动态地调整其CPU和内存资源限制。然而,这并不意味着JVM内的应用程序就可以无限制地使用内存。
在 K8S Pod 中,我们是否有必要指定 Java 堆大小配置
Java 提供了如下三组参数用于限制容器中 Java 堆内存占用大小
- -XX:MaxRAMFraction, -XX:MinRAMFraction
- -XX:MaxRAMPercentage, -XX:MinRAMPercentage
- -Xmx, -Xms
-
MaxRAMFraction/MinRAMFraction
版本支持:’-XX:MaxRAMFraction’, ‘-XX:MinRAMFraction’ JVM 参数仅支持从 Java 8 更新 131 到 Java 8 更新 190。因此,如果您使用任何其他版本的 JDK,则不能使用此选项。
如何配置:如果您打算使用“-XX:MaxRAMFraction” JVM 参数,请确保同时传递这两个额外的 JVM 参数“-XX:+UnlockExperimentalVMOptions -XX:+UseCGroupMemoryLimitForHeap”。只有当您传递这两个 JVM 参数时,JVM 才会从容器的内存大小派生堆大小值,否则,它将从底层主机的内存大小派生堆大小值。具体参考
默认情况下,JVM 分配大