点击“程序员面试吧”,后台回复:“面试”
获取程序员面试宝典
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应用程序。
npx create-react-app docker-image-test
2、命令执行成功后将生成一个基础React应用程序架构cd docker-image-test
yarn install
yarn start
4、通过访问http://localhost:3000可以访问已经启动的应用程序
1、在项目的根目录中创建一个名为Dockerfile的文件,并粘贴以下代码:FROM node:12
WORKDIR /app
COPY package.json ./
RUN yarn install
COPY . .
EXPOSE 3000
CMD ["yarn", "start"]
2、注意,这里我们从Docker仓库获得基础镜像Node:12,然后安装依赖项并运行基本命令。(我们不会在这里讨论Docker命令的细节)docker build -t docker-image-test .
4、Docker构建镜像完成之后,你可以使用此命令查看已经构建的镜像:docker images
在查询结果列表的顶部,是我们新创建的图像,在最右边,我们可以看到图像的大小。目前是1.43GB。docker run --rm -it -p 3000:3000/tcp docker-image-test:latest
1、先前的配置中我们用node:12作为基础镜像。但是传统的Node镜像是基于Ubuntu的,对于我们简单的React应用程序来说这大可不必。2、从DockerHub(官方Docker镜像注册表)中我们可以看到,基于alpine-based的Node镜像比基于Ubuntu的镜像小得多,而且它们的依赖程度非常低。现在我们将使用node:12-alpine作为我们的基础镜像,看看会发生什么。FROM node:12-alpine
WORKDIR /app
COPY package.json ./
RUN yarn install
COPY . .
EXPOSE 3000
CMD ["yarn", "start"]
哇!我们的镜像大小减少到只有580MB,这是一个很大的进步。但还能做得更好吗?
1、在之前的配置中,我们会将所有源代码也复制到工作目录中。2、但这大可不必,因为从发布和运行来看我们只需要构建好的运行目录即可。因此,现在我们将引入多级构建的概念,以减少不必要的代码和依赖于我们的最终镜像。# 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
5、在第二阶段,我们复制上一阶段构建产物目录,并使用它来运行应用程序。6、这样我们在最终的镜像中就不会有不必要的依赖和代码。现在我们的镜像大小只有97.5MB。这简直太棒了。
1、我们正在使用Node服务器运行ReactJS应用程序的静态资源,但这不是静态资源运行的最佳选择。2、我们尝试使用Nginx这类更高效、更轻量级的服务器来运行资源应用程序,也可以尽可能提高其性能,并且减少镜像的量。# 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来服务我们的应用程序。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