在 Java 版本 1.8.0_282 的容器上设置 MaxRAMPercentage

问题描述

我正在 AWS 上使用 Docker 和 Kubernetes(cloudformation yaml)

雅姆

...
resources:
  requests:
    memory: "4Gi"
    cpu: "0.5"
  limits:
    memory: "4Gi"
    cpu: "0.5"

Dockerfile

FROM amazonlinux:latest
RUN yum -y install java-1.8.0
EXPOSE 8103
ADD myapp.jar
ENTRYPOINT ["java","-XX:MinRAMPercentage=50.0","-XX:MaxRAMPercentage=80.0","-jar","myapp.jar"]

跟随你可以从我的pod的bash中找到java“1.8.0_282”的版本

bash-4.2# java -XX:+PrintFlagsFinal  -version | grep -iE 'HeapSize|PermSize|ThreadStackSize'
 intx CompilerThreadStackSize                   = 0                                   {pd product}
uintx ErgoHeapSizeLimit                         = 0                                   {product}
uintx HeapSizePerGCThread                       = 87241520                            {product}
uintx InitialHeapSize                          := 67108864                            {product}
uintx LargePageHeapSizeThreshold                = 134217728                           {product}
uintx MaxHeapSize                              := 1073741824                          {product}
 intx ThreadStackSize                           = 1024                                {pd product}
 intx VMThreadStackSize                         = 1024                                {pd product}
openjdk version "1.8.0_282"
OpenJDK Runtime Environment (build 1.8.0_282-b08)
OpenJDK 64-Bit Server VM (build 25.282-b08,mixed mode)

我读过这篇blog,作者解释说“如果您运行的是 Java 8 update 191 或更高版本,或者 Java 10、11、12、13 等,则不得使用 UseCGroupMemoryLimitForHeap 选项. 相反,您应该使用认激活的 UseContainerSupport。”

因此,我在 ENTRYPOINT 指令中添加了选项“-XX:MinRAMPercentage=50.0”、“-XX:MaxRAMPercentage=80.0”。

ENTRYPOINT ["java","myapp.jar"]

不幸的是,我的 pod 上的 UseContainerSupport 值没有改变,如您所见

bash-4.2# java -XX:+PrintFlagsFinal  -version | grep -E "UseContainerSupport | InitialRAMPercentage | MaxRAMPercentage | MinRAMPercentage"
double InitialRAMPercentage                      = 1.562500                            {product}
double MaxRAMPercentage                          = 25.000000                           {product}
double MinRAMPercentage                          = 50.000000                           {product}
  bool UseContainerSupport                       = true                                {product}
openjdk version "1.8.0_282"
OpenJDK Runtime Environment (build 1.8.0_282-b08)
OpenJDK 64-Bit Server VM (build 25.282-b08,mixed mode)

我也尝试在我的 YAML 中添加 JAVA_OPTS 如下,但没有任何变化

env:
  - name: JAVA_OPTS
    value: "-XX:MinRAMPercentage=50.0 -XX:MaxRAMPercentage=80.0" 

最后的问题:-)

如何以及在何处设置 -XX:MinRAMPercentage 和 -XX:MaxRAMPercentage 选项以修改 MaxRAMPercentage 的认值?我想使用 3Gi 的 4Gi 专用内存(在 yaml 上)

谢谢大家

解决方法

暂无找到可以解决该程序问题的有效方法,小编努力寻找整理中!

如果你已经找到好的解决方法,欢迎将解决方案带上本链接一起发送给小编。

小编邮箱:dio#foxmail.com (将#修改为@)