Fast and flexible static site generator — builds your entire site at creation time rather than on each request.
| Port | 1313 |
| Registry | ghcr.io/daemonless/hugo |
| Source | https://github.com/gohugoio/hugo |
| Website | https://gohugo.io/ |
| Tag | Description | Best For |
|---|---|---|
latest |
Upstream Binary. Built from official release. | Most users. Matches Linux Docker behavior. |
pkg |
FreeBSD Quarterly. Uses stable, tested packages. | Production stability. |
pkg-latest |
FreeBSD Latest. Rolling package updates. | Newest FreeBSD packages. |
Before deploying, ensure your host environment is ready. See the Quick Start Guide for host setup instructions.
services:
hugo:
image: "ghcr.io/daemonless/hugo:latest"
container_name: hugo
environment:
- PUID=1000 # User ID for the application process
- PGID=1000 # Group ID for the application process
- TZ=UTC # Timezone for the container
- HUGO_BASEURL=http://localhost:1313 # Hostname (and path) to the root
volumes:
- "/path/to/containers/hugo/app:/app"
ports:
- "1313:1313"
restart: unless-stopped.env:
# .env
DIRECTOR_PROJECT=hugo
PUID=1000
PGID=1000
TZ=UTC
HUGO_BASEURL=http://localhost:1313
appjail-director.yml:
# appjail-director.yml
options:
- virtualnet: ':<random> default'
- nat:
services:
hugo:
name: hugo
options:
- container: 'boot args:--pull'
- expose: '1313:1313 proto:tcp' \
oci:
user: root
environment:
- PUID: !ENV '${PUID}'
- PGID: !ENV '${PGID}'
- TZ: !ENV '${TZ}'
- HUGO_BASEURL: !ENV '${HUGO_BASEURL}'
volumes:
- hugo_app: /app
volumes:
hugo_app:
device: '/path/to/containers/hugo/app'Makejail:
# Makejail
ARG tag=latest
OPTION overwrite=force
OPTION from=ghcr.io/daemonless/hugo:${tag}
Note: Exposing ports in AppJail means that your service can be reached from remote hosts. If that is not your intention, do not expose the ports and communicate with the service using the IPv4 address assigned by the virtual network.
podman run -d --name hugo \
-p 1313:1313 \
-e PUID=1000 \
-e PGID=1000 \
-e TZ=UTC \
-e HUGO_BASEURL=http://localhost:1313 \
-v /path/to/containers/hugo/app:/app \
ghcr.io/daemonless/hugo:latestappjail oci run -Pd \
-o overwrite=force \
-o container="args:--pull" \
-o virtualnet=":<random> default" \
-o nat \
-o expose="1313:1313 proto:tcp" \
-e PUID=1000 \
-e PGID=1000 \
-e TZ=UTC \
-e HUGO_BASEURL=http://localhost:1313 \
-o fstab="/path/to/containers/hugo/app /app <pseudofs>" \
ghcr.io/daemonless/hugo:latest hugoNote: Exposing ports in AppJail means that your service can be reached from remote hosts. If that is not your intention, do not expose the ports and communicate with the service using the IPv4 address assigned by the virtual network.
- name: Deploy hugo
containers.podman.podman_container:
name: hugo
image: "ghcr.io/daemonless/hugo:latest"
state: started
restart_policy: always
env:
PUID: "1000"
PGID: "1000"
TZ: "UTC"
HUGO_BASEURL: "http://localhost:1313"
ports:
- "1313:1313"
volumes:
- "/path/to/containers/hugo/app:/app"| Variable | Default | Description |
|---|---|---|
PUID |
1000 |
User ID for the application process |
PGID |
1000 |
Group ID for the application process |
TZ |
UTC |
Timezone for the container |
HUGO_BASEURL |
http://localhost:1313 |
Hostname (and path) to the root |
| Path | Description |
|---|---|
/app |
Website source code (mount your repo here) |
| Port | Protocol | Description |
|---|---|---|
1313 |
TCP | Dev Server Port |
Architectures: amd64
User: bsd (UID/GID via PUID/PGID, defaults to 1000:1000)
Base: FreeBSD 15.1
Need help? Join our Discord community.