82 lines
2.6 KiB
Docker
82 lines
2.6 KiB
Docker
# =============================================================================
|
|
# felhom-controller Dockerfile
|
|
# Multi-stage build: Go binary + minimal runtime
|
|
# Supports amd64 (N100 mini PCs) and arm64 (Raspberry Pi)
|
|
# =============================================================================
|
|
|
|
# --- Build stage ---
|
|
FROM golang:1.22-bookworm AS builder
|
|
|
|
ARG TARGETOS=linux
|
|
ARG TARGETARCH
|
|
ARG VERSION=dev
|
|
ARG GIT_COMMIT=unknown
|
|
|
|
WORKDIR /build
|
|
|
|
# Cache dependencies first
|
|
COPY go.mod go.sum ./
|
|
RUN go mod download
|
|
|
|
# Copy source
|
|
COPY . .
|
|
|
|
# Build static binary
|
|
RUN CGO_ENABLED=0 GOOS=${TARGETOS} GOARCH=${TARGETARCH} go build \
|
|
-ldflags="-s -w \
|
|
-X main.Version=${VERSION} \
|
|
-X main.BuildTime=$(date -u +%Y-%m-%dT%H:%M:%SZ) \
|
|
-X main.GitCommit=${GIT_COMMIT}" \
|
|
-o /build/felhom-controller \
|
|
./cmd/controller/
|
|
|
|
# --- Runtime stage ---
|
|
FROM debian:bookworm-slim
|
|
|
|
# Install runtime dependencies:
|
|
# - docker-cli: for "docker compose" commands
|
|
# - ca-certificates: for HTTPS (healthchecks pings, git)
|
|
# - restic: for backup operations
|
|
# - postgresql-client: for pg_dump
|
|
# - default-mysql-client: for mysqldump
|
|
# - sqlite3: for SQLite backup
|
|
# - git: for stack sync from Gitea
|
|
# - curl: for health pings and debugging
|
|
RUN apt-get update && apt-get install -y --no-install-recommends \
|
|
ca-certificates \
|
|
curl \
|
|
git \
|
|
restic \
|
|
postgresql-client \
|
|
default-mysql-client \
|
|
sqlite3 \
|
|
&& rm -rf /var/lib/apt/lists/*
|
|
|
|
# Install docker-cli (without daemon)
|
|
RUN curl -fsSL https://download.docker.com/linux/debian/gpg | gpg --dearmor -o /usr/share/keyrings/docker.gpg \
|
|
&& echo "deb [arch=$(dpkg --print-architecture) signed-by=/usr/share/keyrings/docker.gpg] \
|
|
https://download.docker.com/linux/debian bookworm stable" > /etc/apt/sources.list.d/docker.list \
|
|
&& apt-get update \
|
|
&& apt-get install -y --no-install-recommends docker-ce-cli docker-compose-plugin \
|
|
&& rm -rf /var/lib/apt/lists/*
|
|
|
|
# Create non-root user (but we'll run as root for Docker socket access)
|
|
# The Docker socket requires root or docker group membership
|
|
RUN mkdir -p /opt/docker/felhom-controller/data
|
|
|
|
COPY --from=builder /build/felhom-controller /usr/local/bin/felhom-controller
|
|
|
|
# Copy baked-in app assets (logos, screenshots)
|
|
# These are synced from the felhom.eu website repo before building.
|
|
# See: make sync-assets
|
|
COPY assets/ /usr/share/felhom/assets/
|
|
|
|
# Health check
|
|
HEALTHCHECK --interval=30s --timeout=5s --start-period=10s --retries=3 \
|
|
CMD curl -f http://localhost:8080/api/health || exit 1
|
|
|
|
EXPOSE 8080
|
|
|
|
ENTRYPOINT ["/usr/local/bin/felhom-controller"]
|
|
CMD ["--config", "/opt/docker/felhom-controller/controller.yaml"]
|