2天时间,聊今年最热的 Agent、上下文工程、AI 产品创新等话题。2025 年最后一场~ 了解详情
写点什么

Docker 镜像优化:从 1.16GB 到 22.4MB

  • 2020-12-31
  • 本文字数:1354 字

    阅读完需:约 4 分钟

Docker镜像优化:从1.16GB到22.4MB

Docker 是一个供软件开发人员和系统管理员使用容器构建、运行和与分享应用程序的平台。容器是在独立环境中运行的进程,它运行在自己的文件系统上,该文件系统是使用 docker 镜像构建的。镜像中包含运行应用程序所需的一切(编译后的代码、依赖项、库等等)。镜像使用 Dockerfile 文件定义。


术语 dockerization 或 containerization 通常用于定义创建 Docker 容器的过程。


因为容器具备如下优点,所以很受欢迎:


  • 灵活性:即使是最复杂的应用程序也可以容器化。

  • 轻量化:容器共享主机内核,使得它们远比虚拟机高效。

  • 便携性:可以做到本地编译,到处运行。

  • 松耦合:容器自我封装,一个容器被替换或升级不会打断别的容器。

  • 安全性:容器对进程进行了严格的限制和隔离,而无需用户进行任何配置。


在这篇文章中,我将重点讨论如何优化 Docker 镜像以使其轻量化。


让我们从一个示例开始,在该示例中,我们构建了一个 React 应用程序并将其容器化。运行 npx 命令并创建 Dockerfile 之后,我们得到了如图 1 所示的文件结构。


npx create-react-app app --template typescript



图 1:文件结构


如果我们构建一个基础的 Dockerfile(如下所示),我们最终会得到一个 1.16 GB 的镜像:


FROM node:10

 

WORKDIR /app

COPY app /app

RUN npm install -g webserver.local

RUN npm install && npm run build

 

EXPOSE 3000

CMD webserver.local -d ./build



图 2:镜像的初始大小为 1.16GB


第一步优化:使用轻量化基础镜像


Docker Hub(公共 Docker 仓库)中,有一些镜像可供下载,每个镜像都有不同的特征和大小。


通常,相较于基于其他 Linux 发行版(例如Ubuntu)的镜像,基于AlpineBusyBox的镜像非常小。这是因为 Alpine 镜像和类似的其他镜像都经过了优化,其中仅包含最少的必须的软件包。在下面的图片中,你可以看到 Ubuntu、Alpine、Node 和基于 Alpine 的 Node 镜像之间的大小比较。



图 3:基础镜像的不同大小


通过修改 Dockerfile 并使用 Alpine 作为基础镜像,我们的镜像最终大小为 330MB:


FROM node:10-alpine

 

WORKDIR /app

COPY app /app

RUN npm install -g webserver.local

RUN npm install && npm run build

 

EXPOSE 3000

CMD webserver.local -d ./build


图 4:经过第一步优化后镜像大小为 330MB


第二步优化:多阶段构建


通过多阶段构建,我们可以在 Dockerfile 中使用多个基础镜像,并将编译成品、配置文件等从一个阶段复制到另一个阶段,这样我们就可以丢弃不需要的东西。


在本例中,我们部署 React 应用程序需要的是编译后的代码,我们不需要源文件,也不需要 node_modules 目录和 package.json 文件等。


通过将 Dockerfile 修改为如下内容,我们最终得到的镜像大小为 91.5MB。请记住,来自第一阶段(第 1-4 行)的镜像不会被自动删除,Docker 将它保存在 cache 中,如果我们在另一个构建镜像过程中执行了相同的阶段,就可以使镜像构建更快。所以你必须手动删除第一阶段镜像。


FROM node:10-alpine AS build

WORKDIR /app

COPY app /app

RUN npm install && npm run build

 

 

FROM node:10-alpine

WORKDIR /app

RUN npm install -g webserver.local

COPY --from=build /app/build ./build

EXPOSE 3000

CMD webserver.local -d ./build



图 5:第二步优化后的镜像大小为 91.5MB


现在我们有了一个 Dockerfile,它有两个阶段:在第一个阶段中,我们编译项目,在第二个阶段中,我们在 web 服务器上部署应用程序。然而,Node 容器并不是提供网页(HTML、CSS 和 JavaScript 文件、图片等)服务的最佳选择,最好的选择是使用像 Nginx 或 Apache 这样的服务。在本例中,我将使用 Nginx。


通过将 Dockerfile 修改为如下内容,我们的镜像最终大小是 22.4MB,如果我们运行这个容器,我们可以看到网页可以正常工作,没有任何问题(图 7)。


FROM node:10-alpine AS build

WORKDIR /app

COPY app /app

RUN npm install && npm run build

 

 

FROM nginx:stable-alpine

COPY --from=build /app/build /usr/share/nginx/html

EXPOSE 80

CMD ["nginx", "-g", "daemon off;"]



图 6:第三步优化后的镜像大小为 22.4MB



图 7:最终容器的运行结果


参考



原文链接:


https://medium.com/the-agile-crafter/docker-image-optimization-from-1-16gb-to-22-4mb-53fdb4c53311


2020-12-31 16:444501

评论 2 条评论

发布
用户头像
在构建GO服务镜像过程中,我用到了UPX,能将镜像处理到6M大小
2021-01-01 21:16
回复
用户头像
即使已经做了如此多的优化,但仅仅一个react的前端应用,都需要22MB的硬盘空间,虽然目前硬盘不值钱,但这个资源也是有点大啊。。。
2020-12-31 18:20
回复
没有更多了
发现更多内容

AI 生成代码,从 Copilot 到 Claude Code 的全景测评

掘金安东尼

进入新岗位的第一课——潜龙勿用

老李说技术

职场新人 职场发展 职场妙招

2025年最佳AI摘要追踪工具全解析

qife122

AI搜索 搜索引擎优化

2025年第39周数字取证与事件响应技术动态汇总

qife122

网络安全 数字取证

浅析iGIX多语列的实现

inBuilder低代码平台

jpa 国际化 spring data 多语言支持 iGIX

ShardingSphere 联邦查询 GROUPING 聚合结果问题分析

端小强

#Calcite

资本、开发者入局指南:鸿蒙生态的“高潜力赛道”找到了!

最新动态

CodeBuddy IDE 携手 Lighthouse 实现从设计、代码到部署全流程

六月的雨在InfoQ

CodeBuddy CodeBuddyIDE 无界生成力 CodeBuddyCode

CSRF令牌保护的绕过技术详解

qife122

漏洞挖掘 CSRF攻击

大数据-146 Apache Kudu Docker 快速部署:3 Master/5 TServer 实战与踩坑速查

武子康

大数据 flink spark 分布式 Apache Kudu

司马阅将亮相第二十七届中国国际高新技术成果交易会,助力企业AI在严肃场景中精准落地!

司马阅

Camsys 时间戳信息简介

地平线开发者

自动驾驶; 算法工具链 地平线征程6

Aspire开启云原生开发新纪元:微软推出多语言应用开发平台

qife122

云原生 Aspire

传帮带 人才梯队建设经验总结(16)

万里无云万里天

人才培养 工业 工厂运维

智能车间管理系统:数字化驱动的车间全流程管控生态

深圳亥时科技

过程控制 软件维护经验总结(9)

万里无云万里天

工业 工厂运维 过程控制

工业管理 项目管理经验总结(28)

万里无云万里天

项目管理 工业 工厂运维

PCalc for Mac 万能计算器

做梦万元户

工业设计 自控设计经验总结(17)

万里无云万里天

设计师 工业 工厂运维

Vibe Coding - 零成本使用claude code 、gpt-5、grok-code-fast-1氛围编程

小工匠

vibe coding grok gpt-5 Claude Code

Redis 搭建主从复用-读写分离和主备切换,及重要的关键词解释 部分3

刘大猫

人工智能 云计算 算法 物联网 大模型

从“救火队长”到“AI指挥官”:传统运维的智能化跃迁之路

雅菲奥朗

人工智能 运维 AIOPS

AI智能体-路由模式

Hernon AI

#LangChain AI 智能体 AI开发框架 AI设计方法论 AI开发方法论

C#/.NET/.NET Core优秀项目和框架2025年10月简报

追逐时光者

.net

真正“懂你”的输入法长什么样?讯飞用AI键作答

脑极体

AI

全栈协同 生态共筑——未来物联网开发者论坛深圳启幕,解码开发者落地新路径

新消费日报

LLM 训练基础概念与流程简介

地平线开发者

自动驾驶; 算法工具链 地平线征程6

Spring AI,一个让Spring应用轻松拥抱AI的统一框架

六边形架构

Java Spring AI LLM应用开发 Java大模型开发 Java接入大模型

Fork for Mac Git客户端管理工具

做梦万元户

PyPI发布GitHub Action存在可注入表达式扩展漏洞

qife122

Github Actions 命令注入

GitHub 快速入门指南,新手必备的高效使用手册!

追逐时光者

GitHub

Docker镜像优化:从1.16GB到22.4MB_架构_The Agile Crafter_InfoQ精选文章