脚本宝典收集整理的这篇文章主要介绍了聊聊新版JDK对docker容器的支持,脚本宝典觉得挺不错的,现在分享给大家,也给大家做个参考。
序
本文主要聊聊新版JDK对docker容器的支持
java8及java9
Java 8u131及以上版本开始支持了docker的cpu和memory限制。
cpu limIT
即如果没有显式指定-XX:ParalllelGCThreads 或者 -XX:CICompilerCount, 那么JVM使用docker的cpu限制。如果docker有指定cpu limit,jvm参数也有指定-XX:ParalllelGCThreads 或者 -XX:CICompilerCount,那么以指定的参数为准。
memory limit
在java8u131+及java9,需要加上-XX:+UnlockExperimentaLVMOptions -XX:+UseCGroupMemoryLimitForHeap才能使得XMx感知docker的memory limit。
查看参数默认值
java -XX:+UnlockDiagnosticVMOptions -XX:+UnlockExPErimentalVMOptions -XX:+PRintFlagsFinal
部分输出
bool UseCGroupMemoryLimitForHeap = false {experimental} {default}
可以看到在java9,UseCGroupMemoryLimitForHeap参数还是实验性的,默认关闭。
java10
bool UseCGroupMemoryLimitForHeap = false {experimental} {default}
java10,UseCGroupMemoryLimitForHeap还是experimental,不过标记为废弃。
不过java10新引入了1个参数
int ActiveProcessorCount = -1 {product} {default}
ActiveProcessorCount可以用来指定cpu的个数
java11
java11正式移除UseCGroupMemoryLimitForHeap,代码改动见8194086: Remove deprecated experimental flag UseCGroupMemoryLimitForHeap
同时引入1个新参数
bool UseContainerSupport = true {product} {default}
UseContainerSupport默认为true,可以使用-XLOG:os+container=trace参数来查看详情。
即使使用-XX:-UseContainerSupport禁用了容器支持,-XX:ActiveProcessorCount如果有指定,该参数值仍然会被使用。
小结
参数/版本 -XX:+UseCGroupMemoryLimitForHeap -XX:ActiveProcessorCount -XX:+UseContainerSupport @H_304_150@ java9 experimental,默认false 无 无 java10 experimental,默认false -1 无 java11 移除 -1 product,默认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
以上是脚本宝典为你收集整理的聊聊新版JDK对docker容器的支持全部内容,希望文章能够帮你解决聊聊新版JDK对docker容器的支持所遇到的问题。
本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。