Upgrade to latest Go version + Some Docker image improvements (note)

* Rename /site to /project
* Add ldflags
* Add go and node to the default image
* Add Dart Sass to the default image
* Build the extended version by default
* Add "npm i" install support with custom entry script override
* Adjust cache logic to speed up CGO rebuilds

Closes #12920
See #12885
This commit is contained in:
Bjørn Erik Pedersen 2024-10-09 11:39:36 +02:00
parent 4a79956276
commit 41f69a7255
4 changed files with 111 additions and 32 deletions

View file

@ -4,7 +4,7 @@ parameters:
defaults: &defaults defaults: &defaults
resource_class: large resource_class: large
docker: docker:
- image: bepsays/ci-hugoreleaser:1.22300.20000 - image: bepsays/ci-hugoreleaser:1.22300.20200
environment: &buildenv environment: &buildenv
GOMODCACHE: /root/project/gomodcache GOMODCACHE: /root/project/gomodcache
version: 2 version: 2
@ -60,7 +60,7 @@ jobs:
environment: environment:
<<: [*buildenv] <<: [*buildenv]
docker: docker:
- image: bepsays/ci-hugoreleaser-linux-arm64:1.22300.20000 - image: bepsays/ci-hugoreleaser-linux-arm64:1.22300.20200
steps: steps:
- *restore-cache - *restore-cache
- &attach-workspace - &attach-workspace

View file

@ -2,56 +2,94 @@
# Twitter: https://twitter.com/gohugoio # Twitter: https://twitter.com/gohugoio
# Website: https://gohugo.io/ # Website: https://gohugo.io/
FROM --platform=$BUILDPLATFORM tonistiigi/xx:1.5.0 AS xx ARG GO_VERSION="1.23.2"
ARG ALPINE_VERSION=3.20
FROM --platform=$BUILDPLATFORM golang:1.22.6-alpine AS build FROM --platform=$BUILDPLATFORM tonistiigi/xx:1.5.0 AS xx
FROM --platform=$BUILDPLATFORM golang:${GO_VERSION}-alpine${ALPINE_VERSION} AS gobuild
FROM golang:${GO_VERSION}-alpine${ALPINE_VERSION} AS gorun
FROM gobuild AS build
RUN apk add clang lld
# Set up cross-compilation helpers # Set up cross-compilation helpers
COPY --from=xx / / COPY --from=xx / /
RUN apk add clang lld
# Optionally set HUGO_BUILD_TAGS to "extended" or "nodeploy" when building like so: ARG TARGETPLATFORM
# docker build --build-arg HUGO_BUILD_TAGS=extended . RUN xx-apk add musl-dev gcc g++
ARG HUGO_BUILD_TAGS="none"
ARG CGO=1 # Optionally set HUGO_BUILD_TAGS to "none" or "nodeploy" when building like so:
ENV CGO_ENABLED=${CGO} # docker build --build-arg HUGO_BUILD_TAGS=nodeploy .
ENV GOOS=linux #
ENV GO111MODULE=on # We build the extended version by default.
ARG HUGO_BUILD_TAGS="extended"
ENV CGO_ENABLED=1
ENV GOPROXY=https://proxy.golang.org
ENV GOCACHE=/root/.cache/go-build
ENV GOMODCACHE=/go/pkg/mod
ARG TARGETPLATFORM
WORKDIR /go/src/github.com/gohugoio/hugo WORKDIR /go/src/github.com/gohugoio/hugo
RUN --mount=src=go.mod,target=go.mod \ # For --mount=type=cache the value of target is the default cache id, so
--mount=src=go.sum,target=go.sum \ # for the go mod cache it would be good if we could share it with other Go images using the same setup,
--mount=type=cache,target=/go/pkg/mod \ # but the go build cache needs to be per platform.
go mod download # See this comment: https://github.com/moby/buildkit/issues/1706#issuecomment-702238282
ARG TARGETPLATFORM
# gcc/g++ are required to build SASS libraries for extended version
RUN xx-apk add --no-scripts --no-cache gcc g++ musl-dev git
RUN --mount=target=. \ RUN --mount=target=. \
--mount=type=cache,target=/go/pkg/mod <<EOT --mount=type=cache,target=/go/pkg/mod \
--mount=type=cache,target=/root/.cache/go-build,id=go-build-$TARGETPLATFORM <<EOT
set -ex set -ex
xx-go build -tags "$HUGO_BUILD_TAGS" -o /usr/bin/hugo xx-go build -tags "$HUGO_BUILD_TAGS" -ldflags "-s -w -X github.com/gohugoio/hugo/common/hugo.vendorInfo=docker" -o /usr/bin/hugo
xx-verify /usr/bin/hugo xx-verify /usr/bin/hugo
EOT EOT
# --- FROM gorun AS final
FROM alpine:3.18
COPY --from=build /usr/bin/hugo /usr/bin/hugo COPY --from=build /usr/bin/hugo /usr/bin/hugo
# libc6-compat & libstdc++ are required for extended SASS libraries # libc6-compat are required for extended libraries (libsass, libwebp).
# ca-certificates are required to fetch outside resources (like Twitter oEmbeds) RUN apk add --no-cache \
RUN apk update && \ libc6-compat \
apk add --no-cache ca-certificates libc6-compat libstdc++ git git \
runuser \
curl \
nodejs \
npm
VOLUME /site RUN mkdir -p /var/hugo/bin && \
WORKDIR /site addgroup -Sg 1000 hugo && \
adduser -Sg hugo -u 1000 -h /var/hugo hugo && \
chown -R hugo: /var/hugo && \
# For the Hugo's Git integration to work.
runuser -u hugo -- git config --global --add safe.directory /project && \
# See https://github.com/gohugoio/hugo/issues/9810
runuser -u hugo -- git config --global core.quotepath false
VOLUME /project
WORKDIR /project
USER hugo:hugo
ENV HUGO_CACHEDIR=/cache
ARG BUILDARCH
ENV BUILDARCH=${BUILDARCH}
ENV PATH="/var/hugo/bin:$PATH"
COPY scripts/docker scripts/docker
COPY scripts/docker/entrypoint.sh /entrypoint.sh
# Install default dependencies.
RUN scripts/docker/install_runtimedeps_default.sh
# Update PATH to reflect the new dependencies.
# For more complex setups, we should probably find a way to
# delegate this to the script itself, but this will have to do for now.
# Also, the dart-sass binary is a little special, other binaries can be put/linked
# directly in /var/hugo/bin.
ENV PATH="/var/hugo/bin/dart-sass:$PATH"
# Expose port for live server # Expose port for live server
EXPOSE 1313 EXPOSE 1313
ENTRYPOINT ["hugo"] ENTRYPOINT ["/entrypoint.sh"]
CMD ["--help"] CMD ["--help"]

21
scripts/docker/entrypoint.sh Executable file
View file

@ -0,0 +1,21 @@
#!/bin/sh
# Check if a custom hugo-docker-entrypoint.sh file exists.
if [ -f hugo-docker-entrypoint.sh ]; then
# Execute the custom entrypoint file.
sh hugo-docker-entrypoint.sh "$@"
exit $?
fi
# Check if a package.json file exists.
if [ -f package.json ]; then
# Check if node_modules exists.
if [ ! -d node_modules ]; then
# Install npm packages.
# Note that we deliberately do not use `npm ci` here, as it would fail if the package-lock.json file is not up-to-date,
# which would be the case if you run the container with a different OS or architecture than the one used to create the package-lock.json file.
npm i
fi
fi
exec "hugo" "$@"

View file

@ -0,0 +1,20 @@
#!/bin/sh
set -ex
export DART_SASS_VERSION=1.79.3
# If $BUILDARCH=arm64, then we need to install the arm64 version of Dart Sass,
# otherwise we install the x64 version.
ARCH="x64"
if [ "$BUILDARCH" = "arm64" ]; then
ARCH="arm64"
fi
cd /tmp
curl -LJO https://github.com/sass/dart-sass/releases/download/${DART_SASS_VERSION}/dart-sass-${DART_SASS_VERSION}-linux-${ARCH}.tar.gz
ls -ltr
tar -xf dart-sass-${DART_SASS_VERSION}-linux-${ARCH}.tar.gz
rm dart-sass-${DART_SASS_VERSION}-linux-${ARCH}.tar.gz && \
# The dart-sass folder is added to the PATH by the caller.
mv dart-sass /var/hugo/bin