减少Spring Boot的JVM内存占用的Docker三种配置


该文提出了减少Spring Boot减少JVM占用的三种Dockerfile镜像配置:

  • OpenJ9:取代Hotspot的IBM Eclipse项目。它已经被开发很长一段时间,看起来已经足够成熟,可以用于生产。您可以立即轻松地获益,替换一些基本镜像和一些参数可能足以为您的应用程序提供巨大的推动力 - 我已经通过更改 Dockerfile基本映像替换了一些应用程序,节约了大约 1/3的内存占用,增强了吞吐量。
    FROM adoptopenjdk/openjdk8-openj9:alpine-slim
    COPY target/app.jar /my-app/app.jar
    ENTRYPOINT java $JAVA_OPTS -Xshareclasses -Xquickstart -jar /my-app/app.jar

  • GraalVM:围绕这个由Oracle实验室开发的有前途的虚拟机进行了大量宣传。它为您提供了将应用程序编译为本机镜像的选项,生成镜像非常非常快且内存消耗很少,吸引人眼球的另一个功能是能够与多种语言(如Javascript,Ruby,Python和Java)进行交互操作。
    FROM oracle/graalvm-ce:1.0.0-rc15
    COPY target/app.jar /my-app/app.jar
    ENTRYPOINT java $JAVA_OPTS -jar /my-app/app.jar

  • Fabric8 shell:一个bash脚本,可根据应用程序当前运行环境自动为您配置JVM参数。它可以在这里下载,是这个研究项目的产物。它降低了不少内存:
    FROM java:openjdk-8-alpine
    COPY target/app.jar /my-app/app.jar
    COPY run-java.sh /my-app/run-java.sh
    ENTRYPOINT JAVA_OPTIONS=${JAVA_OPTS} JAVA_APP_JAR=/my-app/app.jar /my-app/run-java.sh


虽然我们在应用解决方案时总是需要考虑上下文,但对我来说,获胜者是OpenJ9,从而以最少的配置实现了生产就绪的性能和内存占用。
虽然仍然没有找到使用不合适的情况,但这并不意味着它将成为一个银弹解决方案,请记住,最好是测试替代品,看看哪种更适合您的需求。

为什么不用GraalVM?
GraalVM是一个伟大的项目,在接下来的几个月里也许它能颠覆让本文的结论,但到目前为止,我发现了一些不能让我想在生产中使用它的东西,特别是Spring Boot。

  • 不是GA - 目前正在发布candidate 15版本
  • 对于没有函数bean定义的Spring Boot,本机镜像仍然无法正常运行
  • 正确构建本机镜像需要做更多的工作
  • 原生镜像速度非常快,但您必须考虑丢失一些JVM功能