89 lines
3.8 KiB
Docker
89 lines
3.8 KiB
Docker
# syntax=docker/dockerfile:1
|
|
# DeepSeek-TUI multi-arch Docker image (#501)
|
|
#
|
|
# Build: docker buildx build --platform linux/amd64,linux/arm64 -t deepseek-tui:latest .
|
|
# Run: docker run --rm -it -e DEEPSEEK_API_KEY -v ~/.deepseek:/home/deepseek/.deepseek deepseek-tui
|
|
#
|
|
# The image ships both binaries (deepseek dispatcher + deepseek-tui runtime)
|
|
# in a minimal runtime layer. No MCP servers or heavy toolchains are included
|
|
# — keep it slim.
|
|
#
|
|
# API keys MUST be passed at runtime (never baked into the image):
|
|
# docker run --rm -it -e DEEPSEEK_API_KEY deepseek-tui
|
|
# Or mount an env file:
|
|
# docker run --rm -it --env-file .env deepseek-tui
|
|
|
|
ARG RUST_VERSION=1.88
|
|
|
|
# ── Stage 1: Build ────────────────────────────────────────────────────
|
|
FROM --platform=$BUILDPLATFORM rust:${RUST_VERSION}-slim-bookworm AS builder
|
|
ARG TARGETPLATFORM
|
|
ARG TARGETARCH
|
|
ARG BUILDPLATFORM
|
|
ARG DEEPSEEK_BUILD_SHA
|
|
|
|
ENV CC_aarch64_unknown_linux_gnu=aarch64-linux-gnu-gcc \
|
|
CARGO_TARGET_AARCH64_UNKNOWN_LINUX_GNU_LINKER=aarch64-linux-gnu-gcc \
|
|
PKG_CONFIG_ALLOW_CROSS=1 \
|
|
PKG_CONFIG_LIBDIR_aarch64_unknown_linux_gnu=/usr/lib/aarch64-linux-gnu/pkgconfig:/usr/share/pkgconfig \
|
|
DEEPSEEK_BUILD_SHA=${DEEPSEEK_BUILD_SHA}
|
|
|
|
RUN if [ "${TARGETARCH}" = "arm64" ] && [ "${BUILDPLATFORM}" != "${TARGETPLATFORM}" ]; then \
|
|
dpkg --add-architecture arm64; \
|
|
fi \
|
|
&& apt-get update \
|
|
&& apt-get install -y --no-install-recommends \
|
|
pkg-config libdbus-1-dev \
|
|
&& if [ "${TARGETARCH}" = "arm64" ] && [ "${BUILDPLATFORM}" != "${TARGETPLATFORM}" ]; then \
|
|
apt-get install -y --no-install-recommends \
|
|
gcc-aarch64-linux-gnu libc6-dev-arm64-cross libdbus-1-dev:arm64; \
|
|
fi \
|
|
&& rm -rf /var/lib/apt/lists/*
|
|
|
|
# Translate Docker platform into Rust target triple.
|
|
# linux/amd64 → x86_64-unknown-linux-gnu
|
|
# linux/arm64 → aarch64-unknown-linux-gnu
|
|
RUN case "${TARGETPLATFORM}" in \
|
|
linux/amd64) echo x86_64-unknown-linux-gnu > /rust-target ;; \
|
|
linux/arm64) echo aarch64-unknown-linux-gnu > /rust-target ;; \
|
|
*) echo "Unsupported platform: ${TARGETPLATFORM}" >&2; exit 1 ;; \
|
|
esac
|
|
|
|
RUN rustup target add "$(cat /rust-target)"
|
|
|
|
WORKDIR /build
|
|
COPY . .
|
|
|
|
# Build both binaries for the target platform. --locked ensures
|
|
# reproducible builds from the committed lockfile.
|
|
RUN --mount=type=cache,id=deepseek-tui-target-${TARGETARCH},target=/build/target,sharing=locked \
|
|
--mount=type=cache,id=deepseek-tui-cargo-registry-${TARGETARCH},target=/usr/local/cargo/registry,sharing=locked \
|
|
--mount=type=cache,id=deepseek-tui-cargo-git-${TARGETARCH},target=/usr/local/cargo/git,sharing=locked \
|
|
cargo build --release --locked --target "$(cat /rust-target)" \
|
|
&& mkdir -p /out \
|
|
&& cp target/$(cat /rust-target)/release/deepseek /out/ \
|
|
&& cp target/$(cat /rust-target)/release/deepseek-tui /out/
|
|
|
|
# ── Stage 2: Runtime ──────────────────────────────────────────────────
|
|
FROM debian:bookworm-slim
|
|
|
|
RUN apt-get update && apt-get install -y --no-install-recommends \
|
|
ca-certificates \
|
|
libdbus-1-3 \
|
|
&& rm -rf /var/lib/apt/lists/*
|
|
|
|
# Non-root user with explicit UID/GID for filesystem ownership clarity.
|
|
RUN groupadd --gid 1000 deepseek \
|
|
&& useradd --create-home --shell /bin/bash --uid 1000 --gid 1000 deepseek
|
|
USER deepseek
|
|
WORKDIR /home/deepseek
|
|
|
|
COPY --from=builder --chown=deepseek:deepseek /out/deepseek /usr/local/bin/deepseek
|
|
COPY --from=builder --chown=deepseek:deepseek /out/deepseek-tui /usr/local/bin/deepseek-tui
|
|
|
|
# The dispatcher expects to find its companion binary next to it.
|
|
# Both are in /usr/local/bin — no further path setup needed.
|
|
|
|
ENTRYPOINT ["deepseek"]
|
|
CMD []
|