导出二进制文件
您是否知道可以使用 Docker 将应用程序构建为独立的二进制文件?有时,您不想将应用程序打包并分发为 Docker 映像。使用 Docker 构建应用程序,并使用导出器将输出保存到磁盘。
默认输出格式docker build
是容器镜像。该映像会自动加载到您的本地映像存储中,您可以在其中从该映像运行容器,或将其推送到注册表。在底层,这使用默认的导出器,称为docker
导出器。
要将构建结果导出为文件,您可以使用local
导出器。导出local
器将构建容器的文件系统保存到主机上的指定目录。
导出二进制文件
要使用local
导出器,请将--output
选项传递给docker build
命令。该--output
标志采用一个参数:主机上要保存文件的目标位置。
以下命令将文件从目标导出server
到主机文件系统上的当前工作目录:
$ docker build --output=. --target=server .
运行此命令会在 处创建一个二进制文件./bin/server
。它是在该
bin/
目录下创建的,因为该文件位于构建容器内。
$ ls -l ./bin
total 14576
-rwxr-xr-x 1 user user 7459368 Apr 6 09:27 server
如果要创建导出两个二进制文件的构建,可以在 Dockerfile 中创建另一个构建阶段,从每个构建阶段复制这两个二进制文件:
# syntax=docker/dockerfile:1
ARG GO_VERSION=1.21
FROM golang:${GO_VERSION}-alpine AS base
WORKDIR /src
RUN --mount=type=cache,target=/go/pkg/mod/ \
--mount=type=bind,source=go.sum,target=go.sum \
--mount=type=bind,source=go.mod,target=go.mod \
go mod download -x
FROM base as build-client
RUN --mount=type=cache,target=/go/pkg/mod/ \
--mount=type=bind,target=. \
go build -o /bin/client ./cmd/client
FROM base as build-server
ARG APP_VERSION="0.0.0+unknown"
RUN --mount=type=cache,target=/go/pkg/mod/ \
--mount=type=bind,target=. \
go build -ldflags "-X main.version=$APP_VERSION" -o /bin/server ./cmd/server
FROM scratch AS client
COPY --from=build-client /bin/client /bin/
ENTRYPOINT [ "/bin/client" ]
FROM scratch AS server
COPY --from=build-server /bin/server /bin/
ENTRYPOINT [ "/bin/server" ]
+
+ FROM scratch AS binaries
+ COPY --from=build-client /bin/client /
+ COPY --from=build-server /bin/server /
现在,您可以binaries
使用--output
导出客户端和服务器二进制文件的选项来构建目标。
$ docker build --output=bin --target=binaries .
$ ls -l ./bin
total 29392
-rwxr-xr-x 1 user user 7581933 Apr 6 09:33 client
-rwxr-xr-x 1 user user 7459368 Apr 6 09:33 server
概括
本节演示了如何使用 Docker 构建和导出独立的二进制文件。这些二进制文件可以自由分发,并且不需要像 Docker 守护进程那样的容器运行时。
到目前为止您生成的二进制文件是 Linux 二进制文件。这是因为构建环境是Linux。如果您的主机操作系统是Linux,则可以运行这些文件。构建在 Mac 或 Windows 计算机上运行的二进制文件需要交叉编译。本指南稍后将对此进行探讨。
相关信息:
下一步
本指南的下一个主题是测试:如何使用 Docker 运行应用程序测试。