Docker中的多级版本是一项功能,它允许您使用Dockerfile中的FROM
中的多个。每个FROM
都可以启动构建过程的新阶段,您可以将工件从一个阶段复制到另一个阶段。该方法对于通过将构建环境与运行时环境区分开来创建较小,更安全的Docker图像特别有用。
这是您可以使用多阶段构建来实现这一目标的方法:
定义构建阶段:首先定义一个构建阶段,在该阶段中,您可以编译应用程序或准备工件。例如,您可以使用golang
图像来编译GO应用程序。
<code class="Dockerfile">FROM golang:1.16 as builder WORKDIR /app COPY . . RUN go build -o myapp</code>
定义运行时阶段:在构建阶段之后,用最小的基本图像定义运行时阶段。仅将构建阶段的必要工件复制到此运行时阶段。
<code class="Dockerfile">FROM alpine:3.14 COPY --from=builder /app/myapp /myapp CMD ["/myapp"]</code>
通过使用多阶段构建,您最终获得了最终图像,该图像仅包含运行您的应用程序所需的内容,该应用程序要小得多,并且与用于构建的图像相比,它具有更少的潜在漏洞。
在多阶段的Docker构建中有效地组织代码可以大大提高您的Dockerfile的效率和清晰度。以下是一些最佳实践:
单独的问题:将不同的阶段用于不同的目的(例如,建筑物,测试和部署)。这种关注的分离使您的Dockerfile更容易理解和维护。
<code class="Dockerfile"># Build stage FROM node:14 as builder WORKDIR /app COPY package*.json ./ RUN npm install COPY . . RUN npm run build # Test stage FROM node:14 as tester WORKDIR /app COPY --from=builder /app . RUN npm run test # Runtime stage FROM node:14-alpine WORKDIR /app COPY --from=builder /app/build /app/build CMD ["node", "app/build/index.js"]</code>
最小化层的数量:在可能的情况下组合运行命令以减少图像中的层数。这种练习不仅加快了构建过程,而且还使结果图像较小。
<code class="Dockerfile">RUN apt-get update && \ apt-get install -y some-package && \ rm -rf /var/lib/apt/lists/*</code>
.dockerignore
:创建一个.dockerignore
文件,以排除不必要的文件被复制到Docker构建上下文中。这加快了构建过程并降低图像大小。package.json
,运行npm install
,然后复制应用程序的其余部分。在多阶段码头版中优化缓存可以大大减少构建时间。以下是实现这一目标的几种策略:
操作顺序:将经常更改的命令放在Dockerfile的尽头。 Docker将从Dockerfile的开头缓存层,从而加快后续构建。
<code class="Dockerfile">FROM node:14 as builder WORKDIR /app COPY package*.json ./ RUN npm install COPY . . RUN npm run build</code>
在此示例中, npm install
更改可能性较小,因此已放置在COPY . .
命令。
Leverage BuildKit :Docker BuildKit提供了改进的构建缓存机制。通过设置环境变量DOCKER_BUILDKIT=1
启用buildKit,然后使用新的RUN --mount
命令来安装缓存目录。
<code class="Dockerfile"># syntax=docker/dockerfile:experimental FROM golang:1.16 as builder RUN --mount=type=cache,target=/root/.cache/go-build \ go build -o myapp</code>
.dockerignore
文件将不必要的文件从构建上下文中排除。较小的上下文意味着更少的数据传输和更快的构建。与单级版本相比,多阶段的Docker Build提供了一些安全优势:
通过利用多阶段构建,您可以显着增强Docker图像的安全姿势,同时还可以优化其大小和性能。
以上是如何在Docker中使用多级版本来创建较小,更安全的图像?的详细内容。更多信息请关注PHP中文网其他相关文章!