加入收藏 | 设为首页 | 会员中心 | 我要投稿 辽源站长网 (https://www.0437zz.com/)- 云专线、云连接、智能数据、边缘计算、数据安全!
当前位置: 首页 > 运营中心 > 建站资源 > 优化 > 正文

进击的 Java ,云原生时代的蜕变

发布时间:2019-09-20 16:32:12 所属栏目:优化 来源:易立
导读:【编者的话】云原生时代的来临,与Java 开发者到底有什么联系?有人说,云原生压根不是为了 Java 存在的。然而,本文的作者却认为云原生时代,Java 依然可以胜任巨人的角色。作者希望通过一系列实验,开拓同学视野,提供有益思考。 在企业软件领域,Java 依

检查一下构建出的 Docker 镜像, ”petclinic-openjdk-openj9“ 的大小为 871MB,而基础镜像 ”adoptopenjdk/openjdk8“ 仅有 300MB!这货也太膨胀了!

  1. $ docker images petclinic-openjdk-hotspot 
  2. REPOSITORY                  TAG                 IMAGE ID            CREATED             SIZE 
  3. petclinic-openjdk-hotspot   latest              469f73967d03        26 hours ago        871MB 

原因是:为了构建 Spring 应用,我们在镜像中引入了一系列编译时依赖,如 Git,Maven 等,并产生了大量临时的文件。然而这些内容在运行时是不需要的。

在著名的软件12要素第五条明确指出了,”Strictly separate build and run stages.“ 严格分离构建和运行阶段,不但可以帮助我们提升应用的可追溯性,保障应用交付的一致性,同时也可以减少应用分发的体积,减少安全风险。

镜像瘦身

Docker 提供了 Multi-stage Build(多阶段构建),可以实现镜像瘦身。

进击的 Java ,云原生时代的蜕变

我们将镜像构建分成两个阶段:

  • 在 ”build“ 阶段依然采用 JDK 作为基础镜像,并利用 Maven 进行应用构建;
  • 在最终发布的镜像中,我们会采用 JRE 版本作为基础镜像,并从”build“ 镜像中直接拷贝出生成的 jar 文件。这意味着在最终发布的镜像中,只包含运行时所需必要内容,不包含任何编译时依赖,大大减少了镜像体积。
  1. $ cat Dockerfile.openjdk-slim 
  2. FROM adoptopenjdk/openjdk8 AS build 
  3. RUN sed -i 's/archive.ubuntu.com/mirrors.aliyun.com/' /etc/apt/sources.list 
  4. RUN apt-get update 
  5. RUN apt-get install -y  
  6.     git  
  7.     maven 
  8. WORKDIR /tmp 
  9. RUN git clone https://github.com/spring-projects/spring-petclinic.git 
  10. WORKDIR /tmp/spring-petclinic 
  11. RUN mvn install 
  12. FROM adoptopenjdk/openjdk8:jre8u222-b10-alpine-jre 
  13. COPY --from=build /tmp/spring-petclinic/target/spring-petclinic-2.1.0.BUILD-SNAPSHOT.jar spring-petclinic-2.1.0.BUILD-SNAPSHOT.jar 
  14. CMD ["java","-jar","spring-petclinic-2.1.0.BUILD-SNAPSHOT.jar"] 

查看一下新镜像大小,从 871MB 减少到 167MB!

  1. $ docker build -t petclinic-openjdk-hotspot-slim -f Dockerfile.openjdk-slim . 
  2. ... 
  3. $ docker images petclinic-openjdk-hotspot-slim 
  4. REPOSITORY                       TAG                 IMAGE ID            CREATED             SIZE 
  5. petclinic-openjdk-hotspot-slim   latest              d1f1ca316ec0        26 hours ago        167MB 

镜像瘦身之后将大大加速应用分发速度,我们是否有办法优化应用的启动速度呢?

从 JIT 到 AOT —启动提速

为了解决 Java 启动的性能瓶颈,我们首先需要理解 JVM 的实现原理。

(编辑:辽源站长网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

推荐文章
    热点阅读