"UseContainerSupport" VM参数是什么作用?

29

这个选项在 Docker 文件中是用来做什么的?

ENTRYPOINT java -XX:+UseContainerSupport $JAVA_OPTIONS -jar /myapp.jar
不加这个参数Docker容器会启动吗? 我查看了一篇文章,它说:启用内存支持,但对我来说仍不清楚。
2个回答

38
从Java 10开始,默认情况下启用此参数,用于在分配堆大小时考虑JVM对容器内存限制的影响,而不是主机机器的配置。
此选项已回溯到Java 8: https://www.oracle.com/technetwork/java/javase/8u191-relnotes-5032181.html 示例:
如果您运行:
docker run **-m 1gb** openjdk:8u131 java -XshowSettings:vm -version

结果将会是(在我的Ubuntu机器上,带有8GB内存)
Max. Heap Size (Estimated): 1.68G

我为容器设置了内存限制,但它忽略了并使用了主机配置(默认情况下使用总内存的四分之一)。
现在,如果我运行具有新功能的版本(上面的链接),你会看到容器的内存限制已经被考虑进去了。
docker run **-m 1g** openjdk:8u191-jre-alpine java -XshowSettings:vm -version

结果(总内存/4):
Max. Heap Size (Estimated): 247.50M

我写这篇文章的时候,openjdk:8镜像的最新版本是222,所以你可以使用这个版本。它包含了这个功能。

更多信息请参考:

Java 10中解释了这个标志的使用方法:https://medium.com/adorsys/jvm-memory-settings-in-a-container-environment-64b0840e1d9e

在Java 8中使用这个标志:https://blog.softwaremill.com/docker-support-in-new-java-8-finally-fd595df0ca54


20

可以的。容器将会在没有-XX:+UseContainerSupport选项的情况下启动。

-XX:+UseContainerSupport用于分配更大比例的内存。

为了防止JVM在容器中运行时调整最大堆大小,请设置-XX:-UseContainerSupport选项。

此外,https://www.eclipse.org/openj9/docs/xxusecontainersupport/可能会有所帮助。


20
根据我的阅读,-XX:+UseContainerSupport默认已打开,因此即使在JDK 10及更新版本中没有打开它,也会与打开它相同。只有使用选项-XX:-UseContainerSupport才是有用的来禁用它。但在这种情况下,JVM将无法观察docker容器设置的限制,而是直接读取整个容器主机的限制,因此当进程达到容器限制时,不会得到java.lang.OutOfMemoryError: Java堆空间错误,而是会被强制终止。没有应用程序日志会显示问题...所以简言之,不要禁用这个选项。 - aurelije
Java 8 默认启用了这个参数吗? - Toofy
从发布说明中可以看到,Java8默认已启用此功能: https://www.oracle.com/java/technologies/javase/8u191-relnotes.html - cipher0

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接