如何将Docker镜像从1.43G瘦身到22.4MB

2023-10-29 19:20
文章标签 镜像 docker mb 瘦身 22.4 1.43

本文主要是介绍如何将Docker镜像从1.43G瘦身到22.4MB,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

Docker镜像的大小对于系统的CI/CD等都有影响,尤其是云部署场景。我们在生产实践中都会做瘦身的操作,尽最大的可能使用Size小的镜像完成功能。下文是一个简单的ReactJS程序上线的瘦身体验,希望可以帮助大家找到镜像瘦身的方向和灵感。

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

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

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

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

步骤1:创建项目

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

npx create-react-app docker-image-test

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

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

cd docker-image-test
yarn install
yarn start

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

步骤2:构建第一个镜像

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

FROM node:12WORKDIR /appCOPY package.json ./RUN yarn installCOPY . .EXPOSE 3000CMD ["yarn", "start"]

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

3、现在可以通过终端为容器构建镜像

docker build -t docker-image-test .

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

docker images

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

5、我们使用以下命令运行镜像

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

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

步骤3:修改基础镜像

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

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

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

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

FROM node:12-alpineWORKDIR /appCOPY package.json ./RUN yarn installCOPY . .EXPOSE 3000CMD ["yarn", "start"]

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

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

步骤4:多级构建

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

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

3、配置是这样的:

# STAGE 1FROM node:12-alpine AS buildWORKDIR /appCOPY package.json ./RUN yarn  installCOPY . /appRUN yarn build# STAGE 2FROM node:12-alpineWORKDIR /appRUN npm install -g webserver.localCOPY --from=build /app/build ./buildEXPOSE 3000CMD webserver.local -d ./build

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

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

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

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

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

步骤5:使用Nginx

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

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

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

# STAGE 1FROM node:12-alpine AS buildWORKDIR /appCOPY package.json ./RUN yarn  installCOPY . /appRUN yarn build# STAGE 2FROM nginx:stable-alpineCOPY --from=build /app/build /usr/share/nginx/htmlEXPOSE 80CMD ["nginx", "-g", "daemon off;"]

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

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

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

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

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

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

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

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

现在,您的容器确实更加便携和高效了。

今天就到这里。编码快乐!

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

Kubernetes管理员(CKA)培训

本次培训在上海开班,基于最新考纲,通过线下授课、考题解读、模拟演练等方式,帮助学员快速掌握Kubernetes的理论知识和专业技能,并针对考试做特别强化训练,让学员能从容面对CKA认证考试,使学员既能掌握Kubernetes相关知识,又能通过CKA认证考试,学员可多次参加培训,直到通过认证。点击下方图片或者阅读原文链接查看详情。

这篇关于如何将Docker镜像从1.43G瘦身到22.4MB的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/302827

相关文章

SpringBoot+Docker+Graylog 如何让错误自动报警

《SpringBoot+Docker+Graylog如何让错误自动报警》SpringBoot默认使用SLF4J与Logback,支持多日志级别和配置方式,可输出到控制台、文件及远程服务器,集成ELK... 目录01 Spring Boot 默认日志框架解析02 Spring Boot 日志级别详解03 Sp

java实现docker镜像上传到harbor仓库的方式

《java实现docker镜像上传到harbor仓库的方式》:本文主要介绍java实现docker镜像上传到harbor仓库的方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地... 目录1. 前 言2. 编写工具类2.1 引入依赖包2.2 使用当前服务器的docker环境推送镜像2.2

springboot项目打jar制作成镜像并指定配置文件位置方式

《springboot项目打jar制作成镜像并指定配置文件位置方式》:本文主要介绍springboot项目打jar制作成镜像并指定配置文件位置方式,具有很好的参考价值,希望对大家有所帮助,如有错误... 目录一、上传jar到服务器二、编写dockerfile三、新建对应配置文件所存放的数据卷目录四、将配置文

ubuntu如何部署Dify以及安装Docker? Dify安装部署指南

《ubuntu如何部署Dify以及安装Docker?Dify安装部署指南》Dify是一个开源的大模型应用开发平台,允许用户快速构建和部署基于大语言模型的应用,ubuntu如何部署Dify呢?详细请... Dify是个不错的开源LLM应用开发平台,提供从 Agent 构建到 AI workflow 编排、RA

Docker安装MySQL镜像的详细步骤(适合新手小白)

《Docker安装MySQL镜像的详细步骤(适合新手小白)》本文详细介绍了如何在Ubuntu环境下使用Docker安装MySQL5.7版本,包括从官网拉取镜像、配置MySQL容器、设置权限及内网部署,... 目录前言安装1.访问docker镜像仓库官网2.找到对应的版本,复制右侧的命令即可3.查看镜像4.启

debian12安装docker的实现步骤

《debian12安装docker的实现步骤》本文主要介绍了debian12安装docker的实现步骤,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着... 目录步骤 1:更新你的系统步骤 2:安装依赖项步骤 3:添加 docker 的官方 GPG 密钥步骤

Gradle在国内配置镜像加速的实现步骤

《Gradle在国内配置镜像加速的实现步骤》在国内使用Gradle构建项目时,最大的痛点就是依赖下载贼慢,甚至卡死,下面教你如何配置国内镜像加速Gradle下载依赖,主要是通过改写repositori... 目录引言一、修改 build.gradle 或 settings.gradle 的 reposito

Windows Docker端口占用错误及解决方案总结

《WindowsDocker端口占用错误及解决方案总结》在Windows环境下使用Docker容器时,端口占用错误是开发和运维中常见且棘手的问题,本文将深入剖析该问题的成因,介绍如何通过查看端口分配... 目录引言Windows docker 端口占用错误及解决方案汇总端口冲突形成原因解析诊断当前端口情况解

Android Studio 配置国内镜像源的实现步骤

《AndroidStudio配置国内镜像源的实现步骤》本文主要介绍了AndroidStudio配置国内镜像源的实现步骤,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,... 目录一、修改 hosts,解决 SDK 下载失败的问题二、修改 gradle 地址,解决 gradle

Docker镜像修改hosts及dockerfile修改hosts文件的实现方式

《Docker镜像修改hosts及dockerfile修改hosts文件的实现方式》:本文主要介绍Docker镜像修改hosts及dockerfile修改hosts文件的实现方式,具有很好的参考价... 目录docker镜像修改hosts及dockerfile修改hosts文件准备 dockerfile 文