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

这篇具有很好参考价值的文章主要介绍了如何优雅的将 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:创建项目

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

$ npx create-react-app docker-image-test

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

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

$ cd docker-image-test  
$ yarn install  
$ yarn start

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

如何优雅的将 Docker 镜像从 1.43G 瘦身到 22.4MB,docker,容器,运维

2步骤2:构建第一个镜像

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

FROM node:12  
WORKDIR /app  
COPY package.json ./  
RUN yarn install  
COPY . .  
EXPOSE 3000  
CMD \["yarn", "start"\]

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

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

$ docker build -t docker-image-test .

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

$ docker images

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

如何优雅的将 Docker 镜像从 1.43G 瘦身到 22.4MB,docker,容器,运维

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

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

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

3步骤3:修改基础镜像

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

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

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

如何优雅的将 Docker 镜像从 1.43G 瘦身到 22.4MB,docker,容器,运维

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

FROM node:12-alpine  
WORKDIR /app  
COPY package.json ./  
RUN yarn install  
COPY . .  
EXPOSE 3000  
CMD \["yarn", "start"\]

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

如何优雅的将 Docker 镜像从 1.43G 瘦身到 22.4MB,docker,容器,运维

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

4步骤4:多级构建

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

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

3、配置是这样的:

# STAGE 1  
  
FROM node:12-alpine AS build  
WORKDIR /app  
COPY package.json ./  
RUN yarn  install  
COPY . /app  
RUN yarn build  
  
# STAGE 2  
  
FROM node:12-alpine  
WORKDIR /app  
RUN npm install -g webserver.local  
COPY --from=build /app/build ./build  
EXPOSE 3000  
CMD webserver.local -d ./build

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

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

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

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

如何优雅的将 Docker 镜像从 1.43G 瘦身到 22.4MB,docker,容器,运维

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

5步骤5:使用Nginx

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

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

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

# STAGE 1  
  
FROM node:12-alpine AS build  
WORKDIR /app  
COPY package.json ./  
RUN yarn  install  
COPY . /app  
  
RUN yarn build  
  
# STAGE 2  
  
FROM nginx:stable-alpine  
COPY --from=build /app/build /usr/share/nginx/html  
EXPOSE 80  
CMD \["nginx", "-g", "daemon off;"\]

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

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

如何优雅的将 Docker 镜像从 1.43G 瘦身到 22.4MB,docker,容器,运维

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

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

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

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

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

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

现在,您的容器确实更加便携和高效了。文章来源地址https://www.toymoban.com/news/detail-518797.html

到了这里,关于如何优雅的将 Docker 镜像从 1.43G 瘦身到 22.4MB的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • ubuntu-server 22.04自动安装的docker 配置镜像源

    新装了个ubuntu server,安装的时候发现他可以选择安装默认程序包,就选了个docker。 装完后,docker拉gitlab的镜像的时候特别慢,就想换一下国内的镜像源。遇到两个问题。 教程一般是叫你去 /etc/docker/daemon.json 这个路径地下设置镜像站点。 我看了一下咱这docker的进程发现咱这

    2024年02月06日
    浏览(59)
  • 【Docker Desktop】Windows11家庭版安装docker desktop和WSl2(Ubuntu22.04)并完成迁移,配置国内镜像

    目录 一、准备工作 ① 安装Hyper-V ②开启电脑的虚拟化技术,如何确定是否开启了虚拟化技术 ③ 启动Windows功能 二、安装WSl 三、移动Ubuntu 22.04.2 LTS 四、迁移 WSL2 安装位置 五、安装Docker Desktop 六、配置Docker Desktop  七、测试 因为win11家庭版本身是不支持hyper-V的,需要手动安装

    2024年01月20日
    浏览(68)
  • [数据结构 -- C语言] 堆(Heap),你小子就是堆,看我如何透彻的将你拿捏

    目录 1、堆的概念及结构 1.1 概念(概念总是重要的) 1.2 结构,分为两种 1.2.1 小堆/小根堆示例 1.2.2 大堆/大根堆示例 2、堆的接口 3、接口实现 3.1 堆的初始化 3.2 堆的销毁 3.3 堆的插入 功能分析: 功能实现: 3.4 堆的删除 功能分析: 功能实现: 3.5 取堆顶的数据 3.6 堆的数据

    2024年02月07日
    浏览(50)
  • 【docker】 docker-compose如何更新services镜像 | docker-compose如何更新某个镜像 | docker-compose如何重启某个服务

    更新镜像: 首先,确保你已经获取了最新的镜像版本。这可以通过 docker pull 命令来实现,或者直接使用 docker-compose pull 命令更新所有服务的镜像。 拉取 指定 镜像 - 代码如下: 拉取 所有 镜像 - 代码如下: 注意:在拉取更新的镜像后,docker-compose不会自动重新启动服务。你需要

    2024年02月06日
    浏览(48)
  • 【2023最新版】Win11: WSL(Ubuntu22.04)使用docker远程容器教程(Windows的Docker Desktop下载安装、迁移到非系统盘、配置国内镜像源、设置 WSL2)

    目录 一、准备工作 1. 安装WSL(适用于 Linux 的 Windows 子系统) 2. docker简介——来源chatGPT 二、Windows安装 Docker Desktop 1. 官网链接 2. 安装过程 3. 迁移到非系统盘 4. 配置国内镜像源 国内镜像 方法1——通过Docker-Desktop配置 方法2——找打daemon.json文件进行配置 三、在适用于 Wind

    2024年02月12日
    浏览(84)
  • Docker----如何更改docker镜像的存储路径

    【原文链接】Docker----如何更改docker镜像的存储路径 随着docker容器已经镜像的使用,docker镜像占用大量磁盘空间,当然可以通过不断的删除镜像或者设置定时任务删除镜像,但是有时候还是挺麻烦的,而且在一定时间阶段内,可能还是希望多存一些镜像备份用的,此时假如重

    2024年02月11日
    浏览(46)
  • docker 如何批量删除镜像

    docker 使用一段时间之后,可能堆积很多用不着的,或者编译错误的镜像,一个一个删除就很麻烦,需要一个批量删除的方法,如下: 上面这条命令,可以删除所有名字中带 “none” 的镜像,即可以把所有编译错误的镜像删除。 这个 grep 后面的参数,就是筛选出名字中

    2024年02月11日
    浏览(40)
  • 如何修改Docker镜像地址

    在使用docker pull镜像时候,往往出现如下错误: docker: net/http: request canceled while waiting for connection (Client.Timeout exceeded while awaiting headers). 原因就是发现是因为docker加速器超时导致pull不下来。 问题如下 解决方法 1、点击tabar栏中的docker图标,选择Preferences 2、选择Docker Engine项,在

    2024年02月13日
    浏览(44)
  • 如何把优化Docker镜像大小

    Docker是一个开源的虚拟化平台,可以让开发人员将应用程序和依赖项打包在轻量级容器中,然后可以轻松地在任何环境中运行。这样,开发人员可以将容器作为独立的可移植单元在不同的环境中部署和运行应用程序,而不用担心环境的差异会对应用程序的行为产生影响。例如

    2024年02月06日
    浏览(34)
  • Docker中如何删除某个镜像

    1. 停止使用镜像的容器 首先,您需要停止所有正在使用该镜像的容器。您可以使用 docker stop 命令来停止容器: 如果有多个容器使用该镜像,您需要对每个容器都执行停止命令。您可以通过 docker ps -a | grep core-backend-image 来查找所有使用该镜像的容器,并逐一停止它们。 2. 删

    2024年02月22日
    浏览(36)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包