前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >聊聊新版JDK对docker容器的支持

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

作者头像
code4it
发布2018-09-17 16:07:14
2.8K0
发布2018-09-17 16:07:14
举报
文章被收录于专栏:码匠的流水账码匠的流水账

本文主要聊聊新版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。

查看参数默认值

代码语言:javascript
复制
java -XX:+UnlockDiagnosticVMOptions -XX:+UnlockExperimentalVMOptions -XX:+PrintFlagsFinal

部分输出

代码语言:javascript
复制
     bool UseCGroupMemoryLimitForHeap              = false                               {experimental} {default}

可以看到在java9,UseCGroupMemoryLimitForHeap参数还是实验性的,默认关闭。

java10

代码语言:javascript
复制
     bool UseCGroupMemoryLimitForHeap              = false                               {experimental} {default}

java10,UseCGroupMemoryLimitForHeap还是experimental,不过标记为废弃。

不过java10新引入了1个参数

代码语言:javascript
复制
      int ActiveProcessorCount                     = -1                                       {product} {default}

ActiveProcessorCount可以用来指定cpu的个数

java11

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

同时引入1个新参数

代码语言:javascript
复制
     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

  • 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
本文参与 腾讯云自媒体分享计划,分享自微信公众号。
原始发表:2018-04-02,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 码匠的流水账 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • java8及java9
    • cpu limit
      • memory limit
      • java10
      • java11
      • 小结
      • doc
      相关产品与服务
      容器服务
      腾讯云容器服务(Tencent Kubernetes Engine, TKE)基于原生 kubernetes 提供以容器为核心的、高度可扩展的高性能容器管理服务,覆盖 Serverless、边缘计算、分布式云等多种业务部署场景,业内首创单个集群兼容多种计算节点的容器资源管理模式。同时产品作为云原生 Finops 领先布道者,主导开源项目Crane,全面助力客户实现资源优化、成本控制。
      领券
      问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档