聊聊新版JDK对docker容器的支持

本文主要聊聊新版JDK对docker容器的支持java

java8及java9

Java 8u131及以上版本开始支持了Docker的cpu和memory限制。docker

cpu limit

即若是没有显式指定-XX:ParalllelGCThreads 或者 -XX:CICompilerCount, 那么JVM使用docker的cpu限制。若是docker有指定cpu limit,jvm参数也有指定-XX:ParalllelGCThreads 或者 -XX:CICompilerCount,那么以指定的参数为准。api

memory limit

在java8u131+及java9,须要加上-XX:+UnlockExperimentalVMOptions -XX:+UseCGroupMemoryLimitForHeap才能使得Xmx感知docker的memory limit。oracle

查看参数默认值jvm

java -XX:+UnlockDiagnosticVMOptions -XX:+UnlockExperimentalVMOptions -XX:+PrintFlagsFinal

部分输出.net

bool UseCGroupMemoryLimitForHeap              = false                               {experimental} {default}
能够看到在java9,UseCGroupMemoryLimitForHeap参数仍是实验性的,默认关闭。

java10

bool UseCGroupMemoryLimitForHeap              = false                               {experimental} {default}
java10,UseCGroupMemoryLimitForHeap仍是experimental,不过标记为废弃。

不过java10新引入了1个参数code

int ActiveProcessorCount                     = -1                                       {product} {default}
ActiveProcessorCount能够用来指定cpu的个数

java11

java11正式移除UseCGroupMemoryLimitForHeap,代码改动见8194086: Remove deprecated experimental flag UseCGroupMemoryLimitForHeaporm

同时引入1个新参数blog

bool UseContainerSupport                      = true                                     {product} {default}
UseContainerSupport默认为true,可使用-Xlog:os+container=trace参数来查看详情。
即便使用-XX:-UseContainerSupport禁用了容器支持,-XX:ActiveProcessorCount若是有指定,该参数值仍然会被使用。

小结

参数/版本 -XX:+UseCGroupMemoryLimitForHeap -XX:ActiveProcessorCount -XX:+UseContainerSupport
java9 experimental,默认false
java10 experimental,默认false -1
java11 移除 -1 product,默认true

doc

相关文章
相关标签/搜索