微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

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

如何解决在 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 举报,一经查实,本站将立刻删除。