序
本文主要聊聊新版JDK對(duì)docker容器的支持
java8及java9
Java 8u131及以上版本開(kāi)始支持了Docker的cpu和memory限制诺凡。
cpu limit
即如果沒(méi)有顯式指定-XX:ParalllelGCThreads 或者 -XX:CICompilerCount, 那么JVM使用docker的cpu限制践惑。如果docker有指定cpu limit,jvm參數(shù)也有指定-XX:ParalllelGCThreads 或者 -XX:CICompilerCount尔觉,那么以指定的參數(shù)為準(zhǔn)侦铜。
memory limit
在java8u131+及java9,需要加上-XX:+UnlockExperimentalVMOptions -XX:+UseCGroupMemoryLimitForHeap才能使得Xmx感知docker的memory limit钉稍。
查看參數(shù)默認(rèn)值
java -XX:+UnlockDiagnosticVMOptions -XX:+UnlockExperimentalVMOptions -XX:+PrintFlagsFinal
部分輸出
bool UseCGroupMemoryLimitForHeap = false {experimental} {default}
可以看到在java9,UseCGroupMemoryLimitForHeap參數(shù)還是實(shí)驗(yàn)性的种樱,默認(rèn)關(guān)閉。
java10
bool UseCGroupMemoryLimitForHeap = false {experimental} {default}
java10害幅,UseCGroupMemoryLimitForHeap還是experimental岂昭,不過(guò)標(biāo)記為廢棄。
不過(guò)java10新引入了1個(gè)參數(shù)
int ActiveProcessorCount = -1 {product} {default}
ActiveProcessorCount可以用來(lái)指定cpu的個(gè)數(shù)
java11
java11正式移除UseCGroupMemoryLimitForHeap叼风,代碼改動(dòng)見(jiàn)8194086: Remove deprecated experimental flag UseCGroupMemoryLimitForHeap
同時(shí)引入1個(gè)新參數(shù)
bool UseContainerSupport = true {product} {default}
UseContainerSupport默認(rèn)為true棍苹,可以使用-Xlog:os+container=trace參數(shù)來(lái)查看詳情。
即使使用-XX:-UseContainerSupport禁用了容器支持枢里,-XX:ActiveProcessorCount如果有指定,該參數(shù)值仍然會(huì)被使用彬碱。
小結(jié)
參數(shù)/版本 | -XX:+UseCGroupMemoryLimitForHeap | -XX:ActiveProcessorCount | -XX:+UseContainerSupport |
---|---|---|---|
java9 | experimental奥洼,默認(rèn)false | 無(wú) | 無(wú) |
java10 | experimental,默認(rèn)false | -1 | 無(wú) |
java11 | 移除 | -1 | product嚼沿,默認(rèn)true |
doc
- Java SE support for Docker CPU and memory limits
- Docker CPU limits
- Experimental support for Docker memory limits
- Docker memory limits
- What to Expect from Java 10?—?One Developer’s View
- Remove deprecated experimental flag UseCGroupMemoryLimitForHeap
- 8194086: Remove deprecated experimental flag UseCGroupMemoryLimitForHeap
- Improve docker container detection and resource configuration usage