Docker镜像瘦身:从1.43G到22.4MB

Docker镜像瘦身:从1.43G到22.4MB

作者:张亚龙译 2021-08-30 07:08:59

云计算 Docker 镜像的大小对于系统的 CI/CD 等都有影响,尤其是云部署场景。我们在生产实践中都会做瘦身的操作,尽最大的可能使用 Size 小的镜像完成功能。

[[420174]]

图片来自 包图网

下文是一个简单的 ReactJS 程序上线的瘦身体验,希望可以帮助大家找到镜像瘦身的方向和灵感。

如果你正在做 Web 开发相关工作,那么你可能已经知道容器化的概念,以及知道它强大的功能等等。

但在使用 Docker 时,镜像大小至关重要。我们从 create-react-app (https://reactjs.org/docs/create-a-new-react-app.html)获得的样板项目通常都超过 1.43 GB。

今天,我们将容器化一个 ReactJS 应用程序,并学习一些关于如何减少镜像大小并提高性能的技巧。

我们将以 ReactJS 为例,但它适用于任何类型的 NodeJS 应用程序。

步骤 1:创建项目

①借助脚手架通过命令行模式创建 React 项目:

  1. npx create-react-app docker-image-test 

②命令执行成功后将生成一个基础 React 应用程序架构。

③我们可以进入项目目录安装依赖并运行项目:

  1. cd docker-image-test 
  2. yarn install 
  3. yarn start 

④通过访问 http://localhost:3000 可以访问已经启动的应用程序。

步骤 2:构建第一个镜像

①在项目的根目录中创建一个名为 Dockerfile 的文件,并粘贴以下代码:

  1. FROM node:12 
  2.  
  3. WORKDIR /app 
  4.  
  5. COPY package.json ./ 
  6.  
  7. RUN yarn install 
  8.  
  9. COPY . . 
  10.  
  11. EXPOSE 3000 
  12.  
  13. CMD ["yarn""start"

②注意,这里我们从 Docker 仓库获得基础镜像 Node:12,然后安装依赖项并运行基本命令。(我们不会在这里讨论 Docker 命令的细节)

③现在可以通过终端为容器构建镜像:

  1. docker build -t docker-image-test . 

④Docker 构建镜像完成之后,你可以使用此命令查看已经构建的镜像:

  1. docker images 

在查询结果列表的顶部,是我们新创建的图像,在最右边,我们可以看到图像的大小。目前是 1.43GB。

⑤我们使用以下命令运行镜像:

  1. docker run --rm -it -p 3000:3000/tcp docker-image-test:latest 

打开浏览器并且刷新页面验证其可以正常运行。

步骤 3:修改基础镜像

①先前的配置中我们用 node:12 作为基础镜像。但是传统的 Node 镜像是基于 Ubuntu 的,对于我们简单的 React 应用程序来说这大可不必。

②从 DockerHub(官方 Docker 镜像注册表)中我们可以看到,基于 alpine-based 的 Node 镜像比基于 Ubuntu 的镜像小得多,而且它们的依赖程度非常低。

③下面显示了这些基本图像的大小比较:

现在我们将使用node:12-alpine作为我们的基础镜像,看看会发生什么。

  1. FROM node:12-alpine 
  2.  
  3. WORKDIR /app 
  4.  
  5. COPY package.json ./ 
  6.  
  7. RUN yarn install 
  8.  
  9. COPY . . 
  10.  
  11. EXPOSE 3000 
  12.  
  13. CMD ["yarn""start"

然后我们以此构建我们的镜像,并与之前做对比。

哇!我们的镜像大小减少到只有 580MB,这是一个很大的进步。但还能做得更好吗?

步骤 4:多级构建

①在之前的配置中,我们会将所有源代码也复制到工作目录中。

②但这大可不必,因为从发布和运行来看我们只需要构建好的运行目录即可。因此,现在我们将引入多级构建的概念,以减少不必要的代码和依赖于我们的最终镜像。

③配置是这样的:

  1. # STAGE 1 
  2.  
  3. FROM node:12-alpine AS build 
  4.  
  5. WORKDIR /app 
  6.  
  7. COPY package.json ./ 
  8.  
  9. RUN yarn  install 
  10.  
  11. COPY . /app 
  12.  
  13. RUN yarn build 
  14.  
  15.  
  16. # STAGE 2 
  17.  
  18. FROM node:12-alpine 
  19.  
  20. WORKDIR /app 
  21.  
  22. RUN npm install -g webserver.local 
  23.  
  24. COPY --from=build /app/build ./build 
  25.  
  26. EXPOSE 3000 
  27.  
  28. CMD webserver.local -d ./build 

④在第一阶段,安装依赖项并构建我们的项目。

⑤在第二阶段,我们复制上一阶段构建产物目录,并使用它来运行应用程序。

⑥这样我们在最终的镜像中就不会有不必要的依赖和代码。

接下来,构建镜像成功后并从列表中查看镜像:

现在我们的镜像大小只有 97.5MB。这简直太棒了。

步骤 5:使用 Nginx

①我们正在使用 Node 服务器运行 ReactJS 应用程序的静态资源,但这不是静态资源运行的最佳选择。

②我们尝试使用 Nginx 这类更高效、更轻量级的服务器来运行资源应用程序,也可以尽可能提高其性能,并且减少镜像的量。

③我们最终的 Docker 配置文件看起来像这样:

  1. # STAGE 1 
  2.  
  3. FROM node:12-alpine AS build 
  4.  
  5. WORKDIR /app 
  6.  
  7. COPY package.json ./ 
  8.  
  9. RUN yarn  install 
  10.  
  11. COPY . /app 
  12.  
  13. RUN yarn build 
  14.  
  15. # STAGE 2 
  16.  
  17. FROM nginx:stable-alpine 
  18.  
  19. COPY --from=build /app/build /usr/share/nginx/html 
  20.  
  21. EXPOSE 80 
  22.  
  23. CMD ["nginx""-g""daemon off;"

④我们正在改变 Docker 配置的第二阶段,以使用 Nginx 来服务我们的应用程序。

⑤然后使用当前配置构建镜像。

⑥镜像大小减少到只有 22.4MB!

⑦同时,我们正在使用一个性能更好的服务器来服务我们出色的应用程序。

⑧我们可以使用以下命令验证应用程序是否仍在工作。

  1. docker run --rm  -it -p 3000:80/tcp docker-image-test:latest 

⑨注意,我们将容器的 80 端口暴露给外部,因为默认情况下,Nginx 将在容器内部的 80 端口上可用。

所以这些是一些简单的技巧,你可以应用到你的任何 NodeJS 项目,以大幅减少镜像大小。

现在,您的容器确实更加便携和高效了。今天就到这里。编码快乐!

作者:张亚龙译

编辑:陶家龙

出处:转载自公众号分布式实验室(ID:dockerone)

出处:https://javascript.plainenglish.io/how-i-reduced-docker-image-size-from-1-43-gb-to-22-4-mb-84058d70574b

 

文章来源网络,作者:运维,如若转载,请注明出处:https://shuyeidc.com/wp/247462.html<

(0)
运维的头像运维
上一篇2025-04-27 03:22
下一篇 2025-04-27 03:23

相关推荐

  • 个人主题怎么制作?

    制作个人主题是一个将个人风格、兴趣或专业领域转化为视觉化或结构化内容的过程,无论是用于个人博客、作品集、社交媒体账号还是品牌形象,核心都是围绕“个人特色”展开,以下从定位、内容规划、视觉设计、技术实现四个维度,详细拆解制作个人主题的完整流程,明确主题定位:找到个人特色的核心主题定位是所有工作的起点,需要先回答……

    2025-11-20
    0
  • 社群营销管理关键是什么?

    社群营销的核心在于通过建立有温度、有价值、有归属感的社群,实现用户留存、转化和品牌传播,其管理需贯穿“目标定位-内容运营-用户互动-数据驱动-风险控制”全流程,以下从五个维度展开详细说明:明确社群定位与目标社群管理的首要任务是精准定位,需明确社群的核心价值(如行业交流、产品使用指导、兴趣分享等)、目标用户画像……

    2025-11-20
    0
  • 香港公司网站备案需要什么材料?

    香港公司进行网站备案是一个涉及多部门协调、流程相对严谨的过程,尤其需兼顾中国内地与香港两地的监管要求,由于香港公司注册地与中国内地不同,其网站若主要服务内地用户或使用内地服务器,需根据服务器位置、网站内容性质等,选择对应的备案路径(如工信部ICP备案或公安备案),以下从备案主体资格、流程步骤、材料准备、注意事项……

    2025-11-20
    0
  • 如何企业上云推广

    企业上云已成为数字化转型的核心战略,但推广过程中需结合行业特性、企业痛点与市场需求,构建系统性、多维度的推广体系,以下从市场定位、策略设计、执行落地及效果优化四个维度,详细拆解企业上云推广的实践路径,精准定位:明确目标企业与核心价值企业上云并非“一刀切”的方案,需先锁定目标客户群体,提炼差异化价值主张,客户分层……

    2025-11-20
    0
  • PS设计搜索框的实用技巧有哪些?

    在PS中设计一个美观且功能性的搜索框需要结合创意构思、视觉设计和用户体验考量,以下从设计思路、制作步骤、细节优化及交互预览等方面详细说明,帮助打造符合需求的搜索框,设计前的规划明确使用场景:根据网站或APP的整体风格确定搜索框的调性,例如极简风适合细线条和纯色,科技感适合渐变和发光效果,电商类则可能需要突出搜索……

    2025-11-20
    0

发表回复

您的邮箱地址不会被公开。必填项已用 * 标注