mirror of
https://github.com/gohugoio/hugo.git
synced 2025-01-10 22:21:55 +00:00
ed2682325a
- Use Alpine for both stages for consistency. - Switch to mage from go install as dictated in the latest docs. - Easy switch to building Hugo Extended by directly setting HUGO_BUILD_TAGS flag at image build time: `docker build --build-arg HUGO_BUILD_TAGS=extended .` - Update to Go 1.13 and Alpine 3.10. - The only possibly breaking change: Moved the `hugo` binary in the final stage from /hugo to /usr/bin/hugo so one can simply run `hugo` without having to search around for its location.
45 lines
1 KiB
Docker
Executable file
45 lines
1 KiB
Docker
Executable file
# GitHub: https://github.com/gohugoio
|
|
# Twitter: https://twitter.com/gohugoio
|
|
# Website: https://gohugo.io/
|
|
|
|
FROM golang:1.13-alpine AS build
|
|
|
|
# Optionally set HUGO_BUILD_TAGS to "extended" when building like so:
|
|
# docker build --build-arg HUGO_BUILD_TAGS=extended .
|
|
ARG HUGO_BUILD_TAGS
|
|
|
|
ARG CGO=1
|
|
ENV CGO_ENABLED=${CGO}
|
|
ENV GOOS=linux
|
|
ENV GO111MODULE=on
|
|
|
|
WORKDIR /go/src/github.com/gohugoio/hugo
|
|
|
|
COPY . /go/src/github.com/gohugoio/hugo/
|
|
|
|
# gcc/g++ are required to build SASS libraries for extended version
|
|
RUN apk update && \
|
|
apk add --no-cache gcc g++ musl-dev && \
|
|
go get github.com/magefile/mage
|
|
|
|
RUN mage hugo && mage install
|
|
|
|
# ---
|
|
|
|
FROM alpine:3.10
|
|
|
|
COPY --from=build /go/bin/hugo /usr/bin/hugo
|
|
|
|
# libc6-compat & libstdc++ are required for extended SASS libraries
|
|
# ca-certificates are required to fetch outside resources (like Twitter oEmbeds)
|
|
RUN apk update && \
|
|
apk add --no-cache ca-certificates libc6-compat libstdc++
|
|
|
|
VOLUME /site
|
|
WORKDIR /site
|
|
|
|
# Expose port for live server
|
|
EXPOSE 1313
|
|
|
|
ENTRYPOINT ["hugo"]
|
|
CMD ["--help"]
|