mirror of
https://github.com/dagu-org/dagu.git
synced 2025-12-28 06:34:22 +00:00
102 lines
3.1 KiB
Docker
102 lines
3.1 KiB
Docker
# syntax=docker/dockerfile:1.4
|
|
# Stage 1: UI Builder
|
|
FROM --platform=$BUILDPLATFORM node:24-alpine AS ui-builder
|
|
ENV PNPM_HOME="/pnpm"
|
|
ENV PATH="$PNPM_HOME:$PATH"
|
|
RUN corepack enable
|
|
|
|
WORKDIR /app
|
|
COPY ui/ ./
|
|
RUN rm -rf node_modules; \
|
|
pnpm install --frozen-lockfile; \
|
|
pnpm build
|
|
|
|
# Stage 2: Go Builder
|
|
FROM --platform=$TARGETPLATFORM golang:1.25-alpine AS go-builder
|
|
ARG LDFLAGS
|
|
ARG TARGETOS
|
|
ARG TARGETARCH
|
|
WORKDIR /app
|
|
COPY . .
|
|
RUN go mod download && rm -rf frontend/assets
|
|
COPY --from=ui-builder /app/dist/ ./internal/service/frontend/assets/
|
|
RUN GOOS=$TARGETOS GOARCH=$TARGETARCH go build -ldflags="${LDFLAGS}" -o ./bin/dagu ./cmd
|
|
|
|
# Stage 3: Final Image
|
|
FROM --platform=$TARGETPLATFORM ubuntu:24.04
|
|
|
|
ARG USER="dagu"
|
|
ARG USER_UID=1000
|
|
ARG USER_GID=$USER_UID
|
|
ARG DAGU_HOME="/var/lib/dagu"
|
|
|
|
# WORKAROUND — Ubuntu 24.04 switched repo signatures to Ed25519.
|
|
# Older base images ship an outdated ubuntu-keyring that cannot verify
|
|
# these signatures, causing “invalid signature” errors on apt update.
|
|
# Temporarily disable signature checking just long enough to install the
|
|
# new keyring, then re-enable normal verification for everything else.
|
|
RUN set -eux; \
|
|
apt-get update -o Acquire::AllowInsecureRepositories=true \
|
|
-o Acquire::AllowDowngradeToInsecureRepositories=true; \
|
|
DEBIAN_FRONTEND=noninteractive \
|
|
apt-get install -y --no-install-recommends ubuntu-keyring ca-certificates; \
|
|
apt-get clean && rm -rf /var/lib/apt/lists/*
|
|
|
|
# Install common tools
|
|
ENV DEBIAN_FRONTEND=noninteractive
|
|
RUN apt-get update && \
|
|
apt-get install -y \
|
|
sudo \
|
|
tzdata \
|
|
jq \
|
|
&& apt-get clean \
|
|
&& rm -rf /var/lib/apt/lists/*
|
|
|
|
COPY --from=go-builder /app/bin/dagu /usr/local/bin/
|
|
COPY ./entrypoint.sh /entrypoint.sh
|
|
|
|
RUN set -eux; \
|
|
# Try to create group with specified GID, fallback if GID in use
|
|
(groupadd -g "${USER_GID}" "${USER}" || groupadd "${USER}") && \
|
|
# Try to create user with specified UID, fallback if UID in use
|
|
(useradd -m -d /home/dagu \
|
|
-u "${USER_UID}" \
|
|
-g "$(getent group "${USER}" | cut -d: -f3)" \
|
|
-s /bin/bash \
|
|
"${USER}" \
|
|
|| useradd -m -d /home/dagu \
|
|
-g "$(getent group "${USER}" | cut -d: -f3)" \
|
|
-s /bin/bash \
|
|
"${USER}") && \
|
|
chmod +x /entrypoint.sh
|
|
|
|
# Create user and set permissions
|
|
RUN set -eux; \
|
|
{ \
|
|
echo 'dagu ALL=(ALL) NOPASSWD:ALL'; \
|
|
echo 'Defaults:dagu !requiretty'; \
|
|
} > /etc/sudoers.d/99-dagu && \
|
|
chmod 0440 /etc/sudoers.d/99-dagu && \
|
|
visudo -cf /etc/sudoers.d/99-dagu
|
|
|
|
# Delete the default ubuntu user
|
|
RUN userdel -f ubuntu
|
|
|
|
# Create the DAGU_HOME directory and set permissions
|
|
RUN mkdir -p "${DAGU_HOME}" && \
|
|
chown -R "${USER_UID}:${USER_GID}" "${DAGU_HOME}" && \
|
|
chmod 755 "${DAGU_HOME}"
|
|
|
|
WORKDIR /home/dagu
|
|
ENV DAGU_HOST=0.0.0.0
|
|
ENV DAGU_PORT=8080
|
|
ENV DAGU_HOME=${DAGU_HOME}
|
|
ENV DAGU_TZ="Etc/UTC"
|
|
ENV PUID=${USER_UID}
|
|
ENV PGID=${USER_GID}
|
|
ENV DOCKER_GID=-1
|
|
ENV DEBIAN_FRONTEND=noninteractive
|
|
EXPOSE 8080
|
|
ENTRYPOINT ["/entrypoint.sh"]
|
|
CMD ["dagu", "start-all"]
|