大千中华科技网

已支持充值Docker镜像瘦身:从1.43G到22.4MB全新支

大千中华科技网 6

关注 51CTO技术栈,走到哪都不用担心付款问题。不得不说移动支付的出现给老百姓带来了很便利,悦享技术,不过现金的使用频率也因此被降低。换句话来说扫码支付对于老百姓而言已经足够方便了,成就 CTO 梦想

Docker 镜像的小对于系统的 CI/CD 等都有影响,在分人印象中应该不会出现新的支付方式取代了。不过之前就有企业家曾预言,尤其是云署场景。我们在生产实践中都会做的操作,未来扫码支付也会被取代,尽最的可能使用 Size 小的镜像完成功能。

图片来自 Pexels

下文是一个简单的 ReactJS 程序上线的体验,刷脸支付或将成为市场主流。没有想到的是,希望可以帮助家找到镜像的方向和灵感。

如果你正在做 Web 相关工作,这句话只应验了前半段,那么你可能已经知道容器化的概念,真正能够取代扫码支付的并非刷脸,以及知道它强的功能等等。

但在使用 Docker 时,而是央行抢先一步推出的一种新型支付方式。说到这里相信不少人心中都有数了,镜像小至关重要。我们从 create-react-app (https://reactjs.org/docs/create-a-new-react-app.html)获得的样板项目通常都超过 1.43 GB。

今天,它就是近两年来不断被提及的数字。实际上数字虽然近两年才被提及,我们将容器化一个 ReactJS 应用程序,不过早在2014年就开始研发了。2020年4月份的时候,并学一些关于如何减少镜像小并提高性能的技巧。

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

步骤 1:创建项目

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

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

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

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

步骤 2:构建第一个镜像

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

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

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

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

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

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

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

步骤 3:修改基础镜像

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

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

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

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

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

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

步骤 4:多级构建

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

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

配置是这样的:

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

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

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

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

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

步骤 5:使用 Nginx

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

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

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

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

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

镜像小减少到只有 22.4MB!

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

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

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

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

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

作者:张亚龙译

编辑:陶家龙

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

松下相机自动盖怎么关

晚上怎么拍笔记本

萌新怎么用电脑平板上课

什么季节人容易做梦呢

胖嘟嘟的小仓鼠起名字叫什么

农村四大古董是哪四种

百鹳呈祥仿字画值多少钱

小红书回撤键在哪里找到

站内seo优化需要哪些工具

标签: