You cannot select more than 25 topics
			Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
		
		
		
		
		
			
		
			
				
	
	
		
			145 lines
		
	
	
		
			4.5 KiB
		
	
	
	
		
			Docker
		
	
			
		
		
	
	
			145 lines
		
	
	
		
			4.5 KiB
		
	
	
	
		
			Docker
		
	
| # syntax=docker/dockerfile:1
 | |
| 
 | |
| ARG GO_VERSION=1.20.7
 | |
| ARG XX_VERSION=1.2.1
 | |
| 
 | |
| ARG DOCKER_VERSION=24.0.2
 | |
| ARG GOTESTSUM_VERSION=v1.9.0
 | |
| ARG REGISTRY_VERSION=2.8.0
 | |
| ARG BUILDKIT_VERSION=v0.11.6
 | |
| 
 | |
| # xx is a helper for cross-compilation
 | |
| FROM --platform=$BUILDPLATFORM tonistiigi/xx:${XX_VERSION} AS xx
 | |
| 
 | |
| FROM --platform=$BUILDPLATFORM golang:${GO_VERSION}-alpine AS golatest
 | |
| 
 | |
| FROM golatest AS gobase
 | |
| COPY --from=xx / /
 | |
| RUN apk add --no-cache file git
 | |
| ENV GOFLAGS=-mod=vendor
 | |
| ENV CGO_ENABLED=0
 | |
| WORKDIR /src
 | |
| 
 | |
| FROM registry:$REGISTRY_VERSION AS registry
 | |
| 
 | |
| FROM moby/buildkit:$BUILDKIT_VERSION AS buildkit
 | |
| 
 | |
| FROM gobase AS docker
 | |
| ARG TARGETPLATFORM
 | |
| ARG DOCKER_VERSION
 | |
| WORKDIR /opt/docker
 | |
| RUN DOCKER_ARCH=$(case ${TARGETPLATFORM:-linux/amd64} in \
 | |
|     "linux/amd64")   echo "x86_64"  ;; \
 | |
|     "linux/arm/v6")  echo "armel"   ;; \
 | |
|     "linux/arm/v7")  echo "armhf"   ;; \
 | |
|     "linux/arm64")   echo "aarch64" ;; \
 | |
|     "linux/ppc64le") echo "ppc64le" ;; \
 | |
|     "linux/s390x")   echo "s390x"   ;; \
 | |
|     *)               echo ""        ;; esac) \
 | |
|   && echo "DOCKER_ARCH=$DOCKER_ARCH" \
 | |
|   && wget -qO- "https://download.docker.com/linux/static/stable/${DOCKER_ARCH}/docker-${DOCKER_VERSION}.tgz" | tar xvz --strip 1
 | |
| RUN ./dockerd --version && ./containerd --version && ./ctr --version && ./runc --version
 | |
| 
 | |
| FROM gobase AS gotestsum
 | |
| ARG GOTESTSUM_VERSION
 | |
| ENV GOFLAGS=
 | |
| RUN --mount=target=/root/.cache,type=cache \
 | |
|   GOBIN=/out/ go install "gotest.tools/gotestsum@${GOTESTSUM_VERSION}" && \
 | |
|   /out/gotestsum --version
 | |
| 
 | |
| FROM gobase AS buildx-version
 | |
| RUN --mount=type=bind,target=. <<EOT
 | |
|   set -e
 | |
|   mkdir /buildx-version
 | |
|   echo -n "$(./hack/git-meta version)" | tee /buildx-version/version
 | |
|   echo -n "$(./hack/git-meta revision)" | tee /buildx-version/revision
 | |
| EOT
 | |
| 
 | |
| FROM gobase AS buildx-build
 | |
| ARG TARGETPLATFORM
 | |
| RUN --mount=type=bind,target=. \
 | |
|   --mount=type=cache,target=/root/.cache \
 | |
|   --mount=type=cache,target=/go/pkg/mod \
 | |
|   --mount=type=bind,from=buildx-version,source=/buildx-version,target=/buildx-version <<EOT
 | |
|   set -e
 | |
|   xx-go --wrap
 | |
|   DESTDIR=/usr/bin VERSION=$(cat /buildx-version/version) REVISION=$(cat /buildx-version/revision) GO_EXTRA_LDFLAGS="-s -w" ./hack/build
 | |
|   xx-verify --static /usr/bin/docker-buildx
 | |
| EOT
 | |
| 
 | |
| FROM gobase AS test
 | |
| ENV SKIP_INTEGRATION_TESTS=1
 | |
| RUN --mount=type=bind,target=. \
 | |
|   --mount=type=cache,target=/root/.cache \
 | |
|   --mount=type=cache,target=/go/pkg/mod \
 | |
|   go test -v -coverprofile=/tmp/coverage.txt -covermode=atomic ./... && \
 | |
|   go tool cover -func=/tmp/coverage.txt
 | |
| 
 | |
| FROM scratch AS test-coverage
 | |
| COPY --from=test /tmp/coverage.txt /coverage.txt
 | |
| 
 | |
| FROM scratch AS binaries-unix
 | |
| COPY --link --from=buildx-build /usr/bin/docker-buildx /buildx
 | |
| 
 | |
| FROM binaries-unix AS binaries-darwin
 | |
| FROM binaries-unix AS binaries-linux
 | |
| 
 | |
| FROM scratch AS binaries-windows
 | |
| COPY --link --from=buildx-build /usr/bin/docker-buildx /buildx.exe
 | |
| 
 | |
| FROM binaries-$TARGETOS AS binaries
 | |
| # enable scanning for this stage
 | |
| ARG BUILDKIT_SBOM_SCAN_STAGE=true
 | |
| 
 | |
| FROM gobase AS integration-test-base
 | |
| # https://github.com/docker/docker/blob/master/project/PACKAGERS.md#runtime-dependencies
 | |
| RUN apk add --no-cache \
 | |
|       btrfs-progs \
 | |
|       e2fsprogs \
 | |
|       e2fsprogs-extra \
 | |
|       ip6tables \
 | |
|       iptables \
 | |
|       openssl \
 | |
|       shadow-uidmap \
 | |
|       xfsprogs \
 | |
|       xz
 | |
| COPY --link --from=gotestsum /out/gotestsum /usr/bin/
 | |
| COPY --link --from=registry /bin/registry /usr/bin/
 | |
| COPY --link --from=docker /opt/docker/* /usr/bin/
 | |
| COPY --link --from=buildkit /usr/bin/buildkitd /usr/bin/
 | |
| COPY --link --from=buildkit /usr/bin/buildctl /usr/bin/
 | |
| COPY --link --from=binaries /buildx /usr/bin/
 | |
| 
 | |
| FROM integration-test-base AS integration-test
 | |
| COPY . .
 | |
| 
 | |
| # Release
 | |
| FROM --platform=$BUILDPLATFORM alpine AS releaser
 | |
| WORKDIR /work
 | |
| ARG TARGETPLATFORM
 | |
| RUN --mount=from=binaries \
 | |
|   --mount=type=bind,from=buildx-version,source=/buildx-version,target=/buildx-version <<EOT
 | |
|   set -e
 | |
|   mkdir -p /out
 | |
|   cp buildx* "/out/buildx-$(cat /buildx-version/version).$(echo $TARGETPLATFORM | sed 's/\//-/g')$(ls buildx* | sed -e 's/^buildx//')"
 | |
| EOT
 | |
| 
 | |
| FROM scratch AS release
 | |
| COPY --from=releaser /out/ /
 | |
| 
 | |
| # Shell
 | |
| FROM docker:$DOCKER_VERSION AS dockerd-release
 | |
| FROM alpine AS shell
 | |
| RUN apk add --no-cache iptables tmux git vim less openssh
 | |
| RUN mkdir -p /usr/local/lib/docker/cli-plugins && ln -s /usr/local/bin/buildx /usr/local/lib/docker/cli-plugins/docker-buildx
 | |
| COPY ./hack/demo-env/entrypoint.sh /usr/local/bin
 | |
| COPY ./hack/demo-env/tmux.conf /root/.tmux.conf
 | |
| COPY --from=dockerd-release /usr/local/bin /usr/local/bin
 | |
| WORKDIR /work
 | |
| COPY ./hack/demo-env/examples .
 | |
| COPY --from=binaries / /usr/local/bin/
 | |
| VOLUME /var/lib/docker
 | |
| ENTRYPOINT ["entrypoint.sh"]
 | |
| 
 | |
| FROM binaries
 |