Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/klakegg/docker-hugo
Truly minimal Docker images for Hugo open-source static site generator.
https://github.com/klakegg/docker-hugo
docker-hugo docker-image hugo
Last synced: about 5 hours ago
JSON representation
Truly minimal Docker images for Hugo open-source static site generator.
- Host: GitHub
- URL: https://github.com/klakegg/docker-hugo
- Owner: klakegg
- License: mit
- Created: 2016-05-22T19:38:00.000Z (over 8 years ago)
- Default Branch: master
- Last Pushed: 2023-06-20T12:59:40.000Z (over 1 year ago)
- Last Synced: 2025-01-05T02:09:38.921Z (7 days ago)
- Topics: docker-hugo, docker-image, hugo
- Language: Shell
- Homepage: https://hub.docker.com/r/klakegg/hugo/
- Size: 543 KB
- Stars: 394
- Watchers: 12
- Forks: 72
- Open Issues: 9
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# Hugo
[![Docker Pulls](https://img.shields.io/docker/pulls/klakegg/hugo.svg)](https://store.docker.com/community/images/klakegg/hugo)
Truly minimal Docker images for [Hugo](http://gohugo.io/) with batteries included.
These images sets `bind` when started as server, otherwise no magic.## Latest tags
Default minimal image based upon [Busybox](https://hub.docker.com/r/_/busybox/):
* Aliases: `latest`, `busybox`, `busybox-ci`, `ci`, `busybox-onbuild`, `onbuild`
* Hugo 0.112.0: `0.112.0-busybox`, `0.112.0`, `0.112.0-busybox-ci`, `0.112.0-ci`, `0.112.0-busybox-onbuild`, `0.112.0-onbuild`Minimal image based upon [Alpine](https://hub.docker.com/r/_/alpine/):
* Aliases: `alpine`, `alpine-ci`, `alpine-onbuild`, `ext-alpine`, `ext-alpine-ci`, `ext-alpine-onbuild`
* Hugo 0.112.0: `0.112.0-alpine`, `0.112.0-alpine-ci`, `0.112.0-alpine-onbuild`, `0.112.0-ext-alpine`, `0.112.0-ext-alpine-ci`, `0.112.0-ext-alpine-onbuild`Minimal image based upon [Alpine](https://hub.docker.com/r/_/alpine/) with [Asciidoctor](http://asciidoctor.org/) installed:
* Aliases: `asciidoctor`, `asciidoctor-ci`, `asciidoctor-onbuild`, `ext-asciidoctor`, `ext-asciidoctor-ci`, `ext-asciidoctor-onbuild`
* Hugo 0.112.0: `0.112.0-asciidoctor`, `0.112.0-asciidoctor-onbuild`, `0.112.0-asciidoctor-ci`, `0.112.0-ext-asciidoctor`, `0.112.0-ext-asciidoctor-ci`, `0.112.0-ext-asciidoctor-onbuild`Minimal image based upon [Alpine](https://hub.docker.com/r/_/alpine/) with [Pandoc](https://pandoc.org/) installed:
* Aliases: `pandoc`, `pandoc-ci`, `pandoc-onbuild`, `ext-pandoc`, `ext-pandoc-ci`, `ext-pandoc-onbuild`
* Hugo 0.112.0: `0.112.0-pandoc`, `0.112.0-pandoc-ci`, `0.112.0-pandoc-onbuild`, `0.112.0-ext-pandoc`, `0.112.0-ext-pandoc-ci`, `0.112.0-ext-pandoc-onbuild`Image based upon [Debian](https://hub.docker.com/r/_/debian/):
* Aliases: `debian`, `debian-ci`, `debian-onbuild`, `ext`, `latest-ext`, `ext-debian`, `ext-debian-ci`, `ext-ci`, `ext-debian-onbuild`, `ext-onbuild`
* Hugo 0.112.0: `0.112.0-debian`, `0.112.0-debian-ci`, `0.112.0-debian-onbuild`, `0.112.0-ext`, `0.112.0-ext-debian`, `0.112.0-ext-debian-ci`, `0.112.0-ext-ci`,`0.112.0-ext-debian-onbuild`, `0.112.0-ext-onbuild`Image based upon [Ubuntu](https://hub.docker.com/r/_/ubuntu/):
* Aliases: `ubuntu`, `ubuntu-ci`, `ubuntu-onbuild`, `ext-ubuntu`, `ext-ubuntu-ci`, `ext-ubuntu-onbuild`
* Hugo 0.112.0: `0.112.0-ubuntu`, `0.112.0-ubuntu-ci`, `0.112.0-ubuntu-onbuild`, `0.112.0-ext-ubuntu`, `0.112.0-ext-ubuntu-ci`, `0.112.0-ext-ubuntu-onbuild`*Looking for older tags? Please see the [complete list of tags](https://github.com/klakegg/docker-hugo/blob/master/doc/tags.md).*
## Using image
This image does not try to do any fancy.
Users may use Hugo [just as they are used to](https://gohugo.io/documentation/).### Command line
Normal build:
```shell
docker run --rm -it \
-v $(pwd):/src \
klakegg/hugo:0.112.0
```Run server:
```shell
docker run --rm -it \
-v $(pwd):/src \
-p 1313:1313 \
klakegg/hugo:0.112.0 \
server
```### docker-compose
Normal build:
```yaml
build:
image: klakegg/hugo:0.112.0
volumes:
- ".:/src"
```Run server:
```yaml
server:
image: klakegg/hugo:0.112.0
command: server
volumes:
- ".:/src"
ports:
- "1313:1313"
```### Github Actions
All versions and variants published using this repository may be used in any combination.
Simple configuration for e.g. `.github/workflows/hugo.yml`:
```yaml
name: Hugoon: [push]
jobs:
build:
runs-on: ubuntu-lateststeps:
- uses: actions/checkout@v1- name: hugo
uses: klakegg/[email protected]
```Find out more in [klakegg/actions-hugo](https://github.com/klakegg/actions-hugo).
### Travis CI
Simple configuration for `.travis.yml`:
```yaml
language: bashservices:
- dockerscript:
- docker run --rm -i \
-v $(pwd):/src \
klakegg/hugo:0.112.0
```The `bash` environment is used for faster loading before Travis is ready to trigger Docker.
## Hugo shell
A Hugo shell is made available in the Alpine/Debian/Ubuntu images (including Asciidoctor/Pandoc images).
Hugo shell is bash and Hugo completion.To get into a shell for your site:
```shell
docker run --rm -it \
-v $(pwd):/src \
klakegg/hugo:0.112.0-alpine \
shell
```## Hugo extended edition
The extended edition is used in those images containing `ext` in the name. Except use of extended edition and additional tools are those images exactly the same as those using the normal edition.
Table of Hugo extention features and the version when images first support the feature:
| Feature | Alpine | Debian | Ubuntu |
| ------------- | ------ | ------ | ------ |
| Hugo extended | 0.43 | 0.43 | 0.43 |
| PostCSS | 0.56.0 | 0.43 | 0.43 |
| NodeJS | 0.54.0 | 0.54.0 | 0.54.0 |
| Yarn | 0.54.0 | 0.54.0 | 0.54.0 |
| Git | 0.56.0 | 0.56.0 | 0.56.0 |
| Autoprefixer | 0.57.0 | 0.57.0 | 0.57.0 |
| Go | 0.68.0 | 0.68.0 | 0.68.0 |
| Babel | 0.71.0 | 0.71.0 | 0.71.0 |
| rst2html | 0.81.0 | 0.81.0 | 0.81.0 |Users of [google/docsy](https://github.com/google/docsy) may use the extended images as of version 0.57.2 to build their site.
## Using ONBUILD image
The onbuild images adds content of the folder of your Dockerfile into `/src` and builds to the `/target` (prior to `0.68.0`: `/onbuild`) folder.
Example Dockerfile for your project where the site is made into an nginx image (Docker 17.05-ce or newer):
```Dockerfile
FROM klakegg/hugo:0.112.0-onbuild AS hugoFROM nginx
COPY --from=hugo /target /usr/share/nginx/html
```Available arguments for `docker build`:
* HUGO_CMD - Commands passed to Hugo during build. Default *empty*
* HUGO_DESTINATION_ARG - Location of output folder. Default: `/target`
* HUGO_ENV_ARG - Selecting environment ("DEV"/"production"). Default: `DEV`
* HUGO_DIR - Selecting Hugo root directory. Default: `/src`## Using CI image (0.77.0 or newer)
The `ci` images are prepared for use in configuration for continuous integration/deployment.
Difference between normal images and `ci` images:
* Environment variable `HUGO_ENV`: `production`
* Entrypoint is empty## Using Pandoc
Hugo images with Pandoc support are made available for users wanting to use Pandoc in combination with Hugo.
[Hugo triggers Pandoc](https://gohugo.io/content-management/formats/#additional-formats-through-external-helpers) with `pandoc --mathjax`.
Some users may want to use other arguments, so to accommodate such a need is an alias `pandoc` created with the content of `HUGO_PANDOC` (default: `pandoc-default`) upon initiation.
The `pandoc` executable is renamed to `pandoc-default` as a new `pandoc` script is provided to hanle the `HUGO_PANDOC` evironment variable.Example of explicit setting `pandoc` alias:
```shell
docker run --rm -it \
-v $(pwd):/src \
-e HUGO_PANDOC="pandoc-default --strip-empty-paragraphs" \
klakegg/hugo:0.112.0-pandoc
```## Overriding entrypoint
Those wanting to override entrypoint in the image may easily do so.
Default entrypoint is `hugo`, a small script wrapping the official Hugo software. If you want to use the official software without any wrapping may you use `hugo-official` as entrypoint.
On command line using `--entrypoint`:
```shell
docker run --rm -it \
-v $(pwd):/src \
--entrypoint hugo-official \
klakegg/hugo:0.112.0
```In docker-compose using `entrypoint`:
```yaml
build:
image: klakegg/hugo:0.112.0
entrypoint: hugo-official
volumes:
- ".:/src"
```## Versions
| Software | Version |
| -------- | ------- |
| Go | 1.19.9 |
| NodeJS | 20.x |
| Pandoc | 2.12 |
| Yarn | 1.22.19 |## Configuration
Environment variables:
* HUGO_BIND - Bind address for server. Default: `0.0.0.0`
* HUGO_CACHEDIR - Cache directory for modules. Default: `/tmp`
* HUGO_DESTINATION - Location of output folder. Default: `public`
* HUGO_PANDOC - Pandoc command to be triggered. Default: `pandoc-default`
* HUGO_ENV - Selecting environment ("DEV"/"production"). Default: `DEV`
* HUGO_VERSION - Version of Hugo bundled in image. Default: *Current version*
* HUGO_VERSION_OVERRIDE - Version of Hugo to use. Requires images for Hugo 0.71.1 or newer. Default: *blank*Ports:
* `1313/tcp`