You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

50 lines
2.1 KiB

# 构建 operator 的镜像
# Build the manager binary
###################### build 阶段 ###########################
# 获取编译需要的环境,并且将这个阶段(镜像)命名为 builder
FROM golang:1.19 as builder
# 参数定义,用户选择性的设置这些参数 TARGETOS="linux" TARGETARCH="amd64|arm64" docker build
ARG TARGETOS
ARG TARGETARCH
# 指定工作目录,后续的命令都是在这个目录下进行
WORKDIR /workspace
# Copy the Go Modules manifests
# 拷贝 go 依赖相关的文件
COPY go.mod go.mod
COPY go.sum go.sum
# cache deps before building and copying source so that we don't need to re-download as much
# and so that source changes don't invalidate our downloaded layer
# 下载依赖
RUN go mod download
# Copy the go source
# 拷贝 operator 相关的文件及文件夹
COPY main.go main.go
COPY api/ api/
COPY controllers/ controllers/
# Build
# the GOARCH has not a default value to allow the binary be built according to the host where the command
# was called. For example, if we call make docker-build in a local env which has the Apple Silicon M1 SO
# the docker BUILDPLATFORM arg will be linux/arm64 when for Apple x86 it will be linux/amd64. Therefore,
# by leaving it empty we can ensure that the container and binary shipped on it will have the same platform.
# 开始执行构建,这里会产出我们需要的可执行的二进制文件
RUN CGO_ENABLED=0 GOOS=${TARGETOS:-linux} GOARCH=${TARGETARCH} go build -a -o manager main.go
######################### 创建运行镜像阶段 ################################
# Use distroless as minimal base image to package the manager binary
# Refer to https://github.com/GoogleContainerTools/distroless for more details
# 定义运行镜像的来源
FROM gcr.io/distroless/static:nonroot
# 指定工作目录,后续的执行都在此目录下
WORKDIR /
# 从 builder 阶段(镜像)中拷贝之前生成的可执行二进制文件
COPY --from=builder /workspace/manager
# 设置运行的账户
USER 65532:65532
# 设置入口文件。如果镜像的时候,我们没有指定运行命令,将会自动运行此命令。
ENTRYPOINT ["/manager"]