【发布时间】:2015-07-07 13:06:56
【问题描述】:
在提出这个问题时,Docker 看起来足够新,以至于在网上没有这个问题的答案。我找到的唯一地方是this article,作者说这很难,仅此而已。
【问题讨论】:
标签: java docker heap-memory
在提出这个问题时,Docker 看起来足够新,以至于在网上没有这个问题的答案。我找到的唯一地方是this article,作者说这很难,仅此而已。
【问题讨论】:
标签: java docker heap-memory
更新:关于本次讨论,Java 已经在容器支持方面进行了升级。现在(或者更准确地说,从 JVM 版本 10 开始),JVM 已经足够智能,可以判断它是否在容器中运行,如果是,它会限制多少内存。
因此,与其在启动 JVM 时设置固定限制,然后您必须根据容器限制的更改(K8s 世界中的资源限制)进行更改,只需 什么都不做,让 JVM 运行限制自己。
无需任何额外配置,JVM 会将最大堆大小设置为已分配内存的 25%。由于这很节俭,您可能希望通过设置-XX:MaxRAMPercentage 属性来增加一点。此外,-XX:InitialRAMPercentage 用于初始堆大小,-XX:MinRAMPercentage 用于内存小于 96MB 的容器。
有关该主题的更多信息,here 是一个很好的概述。
【讨论】:
您可以通过在 docker compose 文件中指定 java 选项环境来做到这一点
env:
- name: _JAVA_OPTIONS
value: "-Xmx1g"
它会改变堆大小。
【讨论】:
我同意这取决于您使用的容器。如果您使用的是官方的Tomcat image,看起来很简单,您需要将JAVA_OPTS 环境变量与您的堆设置一起传递:
docker run --rm -e JAVA_OPTS='-Xmx1g' tomcat
【讨论】:
请注意,在 docker-compose.yml 文件中 - 您需要省略双引号:
environment:
- JVM_OPTS=-Xmx12g -Xms12g -XX:MaxPermSize=1024m
或
environment:
- CATALINA_OPTS=-Xmx12g -Xms12g -XX:MaxPermSize=1024m
【讨论】:
您也可以将这些设置放在您的镜像中,这样您的 Dockerfile 中就会存在如下内容:
ENV JAVA_OPTS="-XX:PermSize=1024m -XX:MaxPermSize=512m"
【讨论】:
这完全取决于您的 Java 应用程序是如何打包的,以及它的配置文件如何使用 Docker 公开。
例如official tomcat image 声明配置文件在默认位置可用:/usr/local/tomcat/conf/
很容易覆盖整个目录或只覆盖一个配置文件:
docker run -it --rm -p 8080:8080 -v $PWD/catalina.properties:/usr/local/tomcat/conf/catalina.properties tomcat:8.0
【讨论】: