mirror of https://github.com/docker/docs.git
				
				
				
			
		
			
				
	
	
		
			152 lines
		
	
	
		
			4.8 KiB
		
	
	
	
		
			Docker
		
	
	
	
			
		
		
	
	
			152 lines
		
	
	
		
			4.8 KiB
		
	
	
	
		
			Docker
		
	
	
	
# syntax=docker/dockerfile:1
 | 
						|
# check=skip=InvalidBaseImagePlatform
 | 
						|
 | 
						|
ARG ALPINE_VERSION=3.21
 | 
						|
ARG GO_VERSION=1.23
 | 
						|
ARG HTMLTEST_VERSION=0.17.0
 | 
						|
ARG HUGO_VERSION=0.141.0
 | 
						|
ARG NODE_VERSION=22
 | 
						|
ARG PAGEFIND_VERSION=1.3.0
 | 
						|
 | 
						|
# base defines the generic base stage
 | 
						|
FROM golang:${GO_VERSION}-alpine${ALPINE_VERSION} AS base
 | 
						|
RUN apk add --no-cache \
 | 
						|
    git \
 | 
						|
    nodejs \
 | 
						|
    npm \
 | 
						|
    gcompat
 | 
						|
 | 
						|
# npm downloads Node.js dependencies
 | 
						|
FROM base AS npm
 | 
						|
ENV NODE_ENV="production"
 | 
						|
WORKDIR /out
 | 
						|
RUN --mount=source=package.json,target=package.json \
 | 
						|
    --mount=source=package-lock.json,target=package-lock.json \
 | 
						|
    --mount=type=cache,target=/root/.npm \
 | 
						|
    npm ci
 | 
						|
 | 
						|
# hugo downloads the Hugo binary
 | 
						|
FROM base AS hugo
 | 
						|
ARG TARGETARCH
 | 
						|
ARG HUGO_VERSION
 | 
						|
WORKDIR /out
 | 
						|
ADD https://github.com/gohugoio/hugo/releases/download/v${HUGO_VERSION}/hugo_extended_${HUGO_VERSION}_linux-${TARGETARCH}.tar.gz .
 | 
						|
RUN tar xvf hugo_extended_${HUGO_VERSION}_linux-${TARGETARCH}.tar.gz
 | 
						|
 | 
						|
# build-base is the base stage used for building the site
 | 
						|
FROM base AS build-base
 | 
						|
WORKDIR /project
 | 
						|
COPY --from=hugo /out/hugo /bin/hugo
 | 
						|
COPY --from=npm /out/node_modules node_modules
 | 
						|
COPY . .
 | 
						|
 | 
						|
# build creates production builds with Hugo
 | 
						|
FROM build-base AS build
 | 
						|
# HUGO_ENV sets the hugo.Environment (production, development, preview)
 | 
						|
ARG HUGO_ENV="development"
 | 
						|
# DOCS_URL sets the base URL for the site
 | 
						|
ARG DOCS_URL="https://docs.docker.com"
 | 
						|
ENV HUGO_CACHEDIR="/tmp/hugo_cache"
 | 
						|
RUN --mount=type=cache,target=/tmp/hugo_cache \
 | 
						|
    hugo --gc --minify -e $HUGO_ENV -b $DOCS_URL
 | 
						|
 | 
						|
# lint lints markdown files
 | 
						|
FROM davidanson/markdownlint-cli2:v0.14.0 AS lint
 | 
						|
USER root
 | 
						|
RUN --mount=type=bind,target=. \
 | 
						|
    /usr/local/bin/markdownlint-cli2 \
 | 
						|
    "content/**/*.md" \
 | 
						|
    "#content/manuals/engine/release-notes/*.md" \
 | 
						|
    "#content/manuals/desktop/previous-versions/*.md"
 | 
						|
 | 
						|
# test validates HTML output and checks for broken links
 | 
						|
FROM wjdp/htmltest:v${HTMLTEST_VERSION} AS test
 | 
						|
WORKDIR /test
 | 
						|
COPY --from=build /project/public ./public
 | 
						|
ADD .htmltest.yml .htmltest.yml
 | 
						|
RUN htmltest
 | 
						|
 | 
						|
# update-modules downloads and vendors Hugo modules
 | 
						|
FROM build-base AS update-modules
 | 
						|
# MODULE is the Go module path and version of the module to update
 | 
						|
ARG MODULE
 | 
						|
RUN <<"EOT"
 | 
						|
set -ex
 | 
						|
if [ -n "$MODULE" ]; then
 | 
						|
    hugo mod get ${MODULE}
 | 
						|
    RESOLVED=$(cat go.mod | grep -m 1 "${MODULE/@*/}" | awk '{print $1 "@" $2}')
 | 
						|
    go mod edit -replace "${MODULE/@*/}=${RESOLVED}";
 | 
						|
else
 | 
						|
    echo "no module set";
 | 
						|
fi
 | 
						|
EOT
 | 
						|
RUN hugo mod vendor
 | 
						|
 | 
						|
# vendor is an empty stage with only vendored Hugo modules
 | 
						|
FROM scratch AS vendor
 | 
						|
COPY --from=update-modules /project/_vendor /_vendor
 | 
						|
COPY --from=update-modules /project/go.* /
 | 
						|
 | 
						|
# build-upstream builds an upstream project with a replacement module
 | 
						|
FROM build-base AS build-upstream
 | 
						|
# UPSTREAM_MODULE_NAME is the canonical upstream repository name and namespace (e.g. moby/buildkit)
 | 
						|
ARG UPSTREAM_MODULE_NAME
 | 
						|
# UPSTREAM_REPO is the repository of the project to validate (e.g. dvdksn/buildkit)
 | 
						|
ARG UPSTREAM_REPO
 | 
						|
# UPSTREAM_COMMIT is the commit hash of the upstream project to validate
 | 
						|
ARG UPSTREAM_COMMIT
 | 
						|
# HUGO_MODULE_REPLACEMENTS is the replacement module for the upstream project
 | 
						|
ENV HUGO_MODULE_REPLACEMENTS="github.com/${UPSTREAM_MODULE_NAME} -> github.com/${UPSTREAM_REPO} ${UPSTREAM_COMMIT}"
 | 
						|
RUN hugo --ignoreVendorPaths "github.com/${UPSTREAM_MODULE_NAME}"
 | 
						|
 | 
						|
# validate-upstream validates HTML output for upstream builds
 | 
						|
FROM wjdp/htmltest:v${HTMLTEST_VERSION} AS validate-upstream
 | 
						|
WORKDIR /test
 | 
						|
COPY --from=build-upstream /project/public ./public
 | 
						|
ADD .htmltest.yml .htmltest.yml
 | 
						|
RUN htmltest
 | 
						|
 | 
						|
# unused-media checks for unused graphics and other media
 | 
						|
FROM alpine:${ALPINE_VERSION} AS unused-media
 | 
						|
RUN apk add --no-cache fd ripgrep
 | 
						|
WORKDIR /test
 | 
						|
RUN --mount=type=bind,target=. ./hack/test/unused_media
 | 
						|
 | 
						|
# path-warnings checks for duplicate target paths
 | 
						|
FROM build-base AS path-warnings
 | 
						|
RUN hugo --printPathWarnings > ./path-warnings.txt
 | 
						|
RUN <<EOT
 | 
						|
DUPLICATE_TARGETS=$(grep "Duplicate target paths" ./path-warnings.txt)
 | 
						|
if [ ! -z "$DUPLICATE_TARGETS" ]; then
 | 
						|
    echo "$DUPLICATE_TARGETS"
 | 
						|
    echo "You probably have a duplicate alias defined. Please check your aliases."
 | 
						|
    exit 1
 | 
						|
fi
 | 
						|
EOT
 | 
						|
 | 
						|
# pagefind installs the Pagefind runtime
 | 
						|
FROM base AS pagefind
 | 
						|
ARG PAGEFIND_VERSION
 | 
						|
COPY --from=build /project/public ./public
 | 
						|
RUN --mount=type=bind,src=pagefind.yml,target=pagefind.yml \
 | 
						|
    npx pagefind@v${PAGEFIND_VERSION} --output-path "/pagefind"
 | 
						|
 | 
						|
# index generates a Pagefind index
 | 
						|
FROM scratch AS index
 | 
						|
COPY --from=pagefind /pagefind .
 | 
						|
 | 
						|
# test-go-redirects checks that the /go/ redirects are valid
 | 
						|
FROM alpine:${ALPINE_VERSION} AS test-go-redirects
 | 
						|
WORKDIR /work
 | 
						|
RUN apk add yq
 | 
						|
COPY --from=build /project/public ./public
 | 
						|
RUN --mount=type=bind,target=. <<"EOT"
 | 
						|
set -ex
 | 
						|
./hack/test/go_redirects
 | 
						|
EOT
 | 
						|
 | 
						|
# release is an empty scratch image with only compiled assets
 | 
						|
FROM scratch AS release
 | 
						|
COPY --from=build /project/public /
 | 
						|
COPY --from=pagefind /pagefind /pagefind
 |