java对docker_Java 对容器(docker)支持

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

同时引入1个新参数

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

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值