mirror of https://github.com/linkerd/linkerd2.git
docker: Parellize CLI builds (#6708)
We currently build all of our CLI binaries serially, but if we have a docker stage for each platform, we can parellize builds for each platform, reducing build times significantly. This change renames `cli/Dockerfile-bin` to `cli/Dockerfile` (so that we get syntax highlighting in editors, etc) and restructures the Dockerfile to have a docker stage for each platform. Then, there are two final stages: 'basic' and 'multi-arch'. The `bin/docker-build-cli-bin` utility typically only builds the `basic` target; when `DOCKER_MULTIARCH` is set, it also builds the target that includes arm binaries.
This commit is contained in:
parent
9da7226fdf
commit
35a9e8b4fb
|
|
@ -15,15 +15,17 @@ rootdir=$( cd "$bindir"/.. && pwd )
|
||||||
# shellcheck source=_tag.sh
|
# shellcheck source=_tag.sh
|
||||||
. "$bindir"/_tag.sh
|
. "$bindir"/_tag.sh
|
||||||
|
|
||||||
|
dockerfile=$rootdir/cli/Dockerfile
|
||||||
|
tag=$(head_root_tag)
|
||||||
|
|
||||||
get_multiarch_argument() {
|
get_multiarch_argument() {
|
||||||
if [ -n "$DOCKER_MULTIARCH" ]; then
|
if [ -n "$DOCKER_MULTIARCH" ]; then
|
||||||
echo "--build-arg BUILD_STAGE=multi-arch"
|
echo "--target=multi-arch"
|
||||||
|
else
|
||||||
|
echo "--target=basic"
|
||||||
fi
|
fi
|
||||||
}
|
}
|
||||||
|
|
||||||
dockerfile=$rootdir/cli/Dockerfile-bin
|
|
||||||
tag=$(head_root_tag)
|
|
||||||
|
|
||||||
# shellcheck disable=SC2046
|
# shellcheck disable=SC2046
|
||||||
docker_build cli-bin "$tag" "$dockerfile" \
|
docker_build cli-bin "$tag" "$dockerfile" \
|
||||||
--build-arg LINKERD_VERSION="$tag" \
|
--build-arg LINKERD_VERSION="$tag" \
|
||||||
|
|
|
||||||
|
|
@ -0,0 +1,84 @@
|
||||||
|
ARG BUILDPLATFORM=linux/amd64
|
||||||
|
|
||||||
|
# Precompile key slow-to-build dependencies
|
||||||
|
FROM --platform=$BUILDPLATFORM golang:1.16.4-alpine as go-deps
|
||||||
|
WORKDIR /linkerd-build
|
||||||
|
COPY go.mod go.sum ./
|
||||||
|
COPY bin/install-deps bin/
|
||||||
|
RUN go mod download
|
||||||
|
RUN ./bin/install-deps
|
||||||
|
|
||||||
|
## compile binaries
|
||||||
|
FROM go-deps as go-gen
|
||||||
|
WORKDIR /linkerd-build
|
||||||
|
COPY cli cli
|
||||||
|
COPY charts charts
|
||||||
|
COPY jaeger jaeger
|
||||||
|
COPY multicluster multicluster
|
||||||
|
COPY viz viz
|
||||||
|
|
||||||
|
COPY controller/k8s controller/k8s
|
||||||
|
COPY controller/api controller/api
|
||||||
|
COPY controller/gen controller/gen
|
||||||
|
COPY pkg pkg
|
||||||
|
|
||||||
|
# Generate static templates
|
||||||
|
# TODO: `go generate` does not honor -mod=readonly
|
||||||
|
RUN go generate -mod=readonly ./pkg/charts/static
|
||||||
|
RUN go generate -mod=readonly ./jaeger/static
|
||||||
|
RUN go generate -mod=readonly ./multicluster/static
|
||||||
|
RUN go generate -mod=readonly ./viz/static
|
||||||
|
|
||||||
|
RUN mkdir -p /out
|
||||||
|
|
||||||
|
FROM go-gen as linux-amd64
|
||||||
|
RUN CGO_ENABLED=0 GOOS=linux GOARCH=amd64 go build -o /out/linkerd -tags prod -mod=readonly -ldflags "-s -w" ./cli
|
||||||
|
ARG LINKERD_VERSION
|
||||||
|
ENV GO_LDFLAGS="-s -w -X github.com/linkerd/linkerd2/pkg/version.Version=${LINKERD_VERSION}"
|
||||||
|
RUN CGO_ENABLED=0 GOOS=linux GOARCH=amd64 go build -o /out/linkerd -tags prod -mod=readonly -ldflags "${GO_LDFLAGS}" ./cli
|
||||||
|
|
||||||
|
FROM go-gen as linux-arm64
|
||||||
|
RUN ./bin/install-deps arm64
|
||||||
|
RUN CGO_ENABLED=0 GOOS=linux GOARCH=arm64 go build -o /out/linkerd -tags prod -mod=readonly -ldflags "-s -w" ./cli
|
||||||
|
ARG LINKERD_VERSION
|
||||||
|
ENV GO_LDFLAGS="-s -w -X github.com/linkerd/linkerd2/pkg/version.Version=${LINKERD_VERSION}"
|
||||||
|
RUN CGO_ENABLED=0 GOOS=linux GOARCH=arm64 go build -o /out/linkerd -tags prod -mod=readonly -ldflags "${GO_LDFLAGS}" ./cli
|
||||||
|
|
||||||
|
FROM go-gen as linux-arm
|
||||||
|
RUN ./bin/install-deps arm
|
||||||
|
RUN CGO_ENABLED=0 GOOS=linux GOARCH=arm go build -o /out/linkerd -tags prod -mod=readonly -ldflags "-s -w" ./cli
|
||||||
|
ARG LINKERD_VERSION
|
||||||
|
ENV GO_LDFLAGS="-s -w -X github.com/linkerd/linkerd2/pkg/version.Version=${LINKERD_VERSION}"
|
||||||
|
RUN CGO_ENABLED=0 GOOS=linux GOARCH=arm go build -o /out/linkerd -tags prod -mod=readonly -ldflags "${GO_LDFLAGS}" ./cli
|
||||||
|
|
||||||
|
FROM go-gen as darwin
|
||||||
|
RUN CGO_ENABLED=0 GOOS=darwin go build -o /out/linkerd -tags prod -mod=readonly -ldflags "-s -w" ./cli
|
||||||
|
ARG LINKERD_VERSION
|
||||||
|
ENV GO_LDFLAGS="-s -w -X github.com/linkerd/linkerd2/pkg/version.Version=${LINKERD_VERSION}"
|
||||||
|
RUN CGO_ENABLED=0 GOOS=darwin go build -o /out/linkerd -tags prod -mod=readonly -ldflags "${GO_LDFLAGS}" ./cli
|
||||||
|
|
||||||
|
FROM go-gen as darwin-arm64
|
||||||
|
RUN CGO_ENABLED=0 GOOS=darwin GOARCH=arm64 go build -o /out/linkerd -tags prod -mod=readonly -ldflags "-s -w" ./cli
|
||||||
|
ARG LINKERD_VERSION
|
||||||
|
ENV GO_LDFLAGS="-s -w -X github.com/linkerd/linkerd2/pkg/version.Version=${LINKERD_VERSION}"
|
||||||
|
RUN CGO_ENABLED=0 GOOS=darwin GOARCH=arm64 go build -o /out/linkerd -tags prod -mod=readonly -ldflags "${GO_LDFLAGS}" ./cli
|
||||||
|
|
||||||
|
FROM go-gen as windows
|
||||||
|
RUN CGO_ENABLED=0 GOOS=windows go build -o /out/linkerd -tags prod -mod=readonly -ldflags "-s -w" ./cli
|
||||||
|
ARG LINKERD_VERSION
|
||||||
|
ENV GO_LDFLAGS="-s -w -X github.com/linkerd/linkerd2/pkg/version.Version=${LINKERD_VERSION}"
|
||||||
|
RUN CGO_ENABLED=0 GOOS=windows go build -o /out/linkerd -tags prod -mod=readonly -ldflags "${GO_LDFLAGS}" ./cli
|
||||||
|
|
||||||
|
FROM scratch as basic
|
||||||
|
COPY LICENSE /linkerd/LICENSE
|
||||||
|
COPY --from=linux-amd64 /out/linkerd /out/linkerd-linux-amd64
|
||||||
|
COPY --from=darwin /out/linkerd /out/linkerd-darwin
|
||||||
|
COPY --from=darwin-arm64 /out/linkerd /out/linkerd-darwin-arm64
|
||||||
|
COPY --from=windows /out/linkerd /out/linkerd-windows
|
||||||
|
# `ENTRYPOINT` prevents `docker build` from otherwise failing with "Error
|
||||||
|
# response from daemon: No command specified."
|
||||||
|
ENTRYPOINT ["/out/linkerd-linux-amd64"]
|
||||||
|
|
||||||
|
FROM basic as multi-arch
|
||||||
|
COPY --from=linux-arm64 /out/linkerd /out/linkerd-linux-arm64
|
||||||
|
COPY --from=linux-arm /out/linkerd /out/linkerd-linux-arm
|
||||||
|
|
@ -1,65 +0,0 @@
|
||||||
ARG BUILDPLATFORM=linux/amd64
|
|
||||||
ARG BUILD_STAGE=single-arch
|
|
||||||
|
|
||||||
# Precompile key slow-to-build dependencies
|
|
||||||
FROM --platform=$BUILDPLATFORM golang:1.16.4-alpine as go-deps
|
|
||||||
WORKDIR /linkerd-build
|
|
||||||
COPY go.mod go.sum ./
|
|
||||||
COPY bin/install-deps bin/
|
|
||||||
RUN go mod download
|
|
||||||
RUN ./bin/install-deps
|
|
||||||
|
|
||||||
## compile binaries
|
|
||||||
FROM go-deps as golang-single-arch
|
|
||||||
WORKDIR /linkerd-build
|
|
||||||
COPY cli cli
|
|
||||||
COPY charts charts
|
|
||||||
COPY jaeger jaeger
|
|
||||||
COPY multicluster multicluster
|
|
||||||
COPY viz viz
|
|
||||||
|
|
||||||
COPY controller/k8s controller/k8s
|
|
||||||
COPY controller/api controller/api
|
|
||||||
COPY controller/gen controller/gen
|
|
||||||
COPY pkg pkg
|
|
||||||
RUN mkdir -p /out
|
|
||||||
|
|
||||||
# Generate static templates
|
|
||||||
# TODO: `go generate` does not honor -mod=readonly
|
|
||||||
RUN go generate -mod=readonly ./pkg/charts/static
|
|
||||||
RUN go generate -mod=readonly ./jaeger/static
|
|
||||||
RUN go generate -mod=readonly ./multicluster/static
|
|
||||||
RUN go generate -mod=readonly ./viz/static
|
|
||||||
|
|
||||||
# Cache builds without version info
|
|
||||||
RUN CGO_ENABLED=0 GOOS=darwin go build -o /out/linkerd-darwin -tags prod -mod=readonly -ldflags "-s -w" ./cli
|
|
||||||
RUN CGO_ENABLED=0 GOOS=darwin GOARCH=arm64 go build -o /out/linkerd-darwin-arm64 -tags prod -mod=readonly -ldflags "-s -w" ./cli
|
|
||||||
RUN CGO_ENABLED=0 GOOS=linux GOARCH=amd64 go build -o /out/linkerd-linux-amd64 -tags prod -mod=readonly -ldflags "-s -w" ./cli
|
|
||||||
RUN CGO_ENABLED=0 GOOS=windows go build -o /out/linkerd-windows -tags prod -mod=readonly -ldflags "-s -w" ./cli
|
|
||||||
|
|
||||||
ARG LINKERD_VERSION
|
|
||||||
ENV GO_LDFLAGS="-s -w -X github.com/linkerd/linkerd2/pkg/version.Version=${LINKERD_VERSION}"
|
|
||||||
RUN CGO_ENABLED=0 GOOS=darwin go build -o /out/linkerd-darwin -tags prod -mod=readonly -ldflags "${GO_LDFLAGS}" ./cli
|
|
||||||
RUN CGO_ENABLED=0 GOOS=darwin GOARCH=arm64 go build -o /out/linkerd-darwin-arm64 -tags prod -mod=readonly -ldflags "${GO_LDFLAGS}" ./cli
|
|
||||||
RUN CGO_ENABLED=0 GOOS=linux GOARCH=amd64 go build -o /out/linkerd-linux-amd64 -tags prod -mod=readonly -ldflags "${GO_LDFLAGS}" ./cli
|
|
||||||
RUN CGO_ENABLED=0 GOOS=windows go build -o /out/linkerd-windows -tags prod -mod=readonly -ldflags "${GO_LDFLAGS}" ./cli
|
|
||||||
|
|
||||||
FROM golang-single-arch as golang-multi-arch
|
|
||||||
RUN ./bin/install-deps arm64
|
|
||||||
RUN ./bin/install-deps arm
|
|
||||||
RUN CGO_ENABLED=0 GOOS=linux GOARCH=arm64 go build -o /out/linkerd-linux-arm64 -tags prod -mod=readonly -ldflags "-s -w" ./cli
|
|
||||||
RUN CGO_ENABLED=0 GOOS=linux GOARCH=arm go build -o /out/linkerd-linux-arm -tags prod -mod=readonly -ldflags "-s -w" ./cli
|
|
||||||
ARG LINKERD_VERSION
|
|
||||||
ENV GO_LDFLAGS="-s -w -X github.com/linkerd/linkerd2/pkg/version.Version=${LINKERD_VERSION}"
|
|
||||||
RUN CGO_ENABLED=0 GOOS=linux GOARCH=arm64 go build -o /out/linkerd-linux-arm64 -tags prod -mod=readonly -ldflags "${GO_LDFLAGS}" ./cli
|
|
||||||
RUN CGO_ENABLED=0 GOOS=linux GOARCH=arm go build -o /out/linkerd-linux-arm -tags prod -mod=readonly -ldflags "${GO_LDFLAGS}" ./cli
|
|
||||||
|
|
||||||
FROM golang-${BUILD_STAGE} as golang
|
|
||||||
|
|
||||||
## export without sources & dependencies
|
|
||||||
FROM scratch
|
|
||||||
COPY LICENSE /linkerd/LICENSE
|
|
||||||
COPY --from=golang /out /out
|
|
||||||
# `ENTRYPOINT` prevents `docker build` from otherwise failing with "Error
|
|
||||||
# response from daemon: No command specified."
|
|
||||||
ENTRYPOINT ["/out/linkerd-linux-amd64"]
|
|
||||||
Loading…
Reference in New Issue