mirror of
https://github.com/gohugoio/hugo.git
synced 2024-11-14 20:37:55 -05:00
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:
parent
4a79956276
commit
41f69a7255
4 changed files with 111 additions and 32 deletions
|
@ -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
|
||||||
|
|
98
Dockerfile
98
Dockerfile
|
@ -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
21
scripts/docker/entrypoint.sh
Executable 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" "$@"
|
20
scripts/docker/install_runtimedeps_default.sh
Executable file
20
scripts/docker/install_runtimedeps_default.sh
Executable 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
|
Loading…
Reference in a new issue