mirror of
https://codeberg.org/Toasterson/solstice-ci.git
synced 2026-04-10 13:20:41 +00:00
- Use `sharing=locked` for cargo build cache mounts across multiple Containerfiles to improve caching efficiency. - Upgrade Traefik to version 3.6 and add support for `DOCKER_API_VERSION` for Podman compatibility. - Extend `.env.sample` with GitHub integration variables and update `.gitignore` with new secrets. - Document GitHub App configuration and webhook integration in Podman README. - Update `github-integration` compose service with environment variables for webhook secret, app ID, key, and API base. Signed-off-by: Till Wegmueller <toasterson@gmail.com>
32 lines
1.4 KiB
Docker
32 lines
1.4 KiB
Docker
# syntax=docker/dockerfile:1.7
|
|
# Build Solstice Orchestrator using upstream official images (no sccache)
|
|
|
|
FROM docker.io/library/rust:bookworm AS builder
|
|
ENV CARGO_HOME=/cargo
|
|
WORKDIR /work
|
|
# Install build dependencies: protoc, headers, pkg-config
|
|
RUN apt-get update \
|
|
&& apt-get install -y --no-install-recommends \
|
|
protobuf-compiler pkg-config libsqlite3-dev libpq-dev libvirt-dev ca-certificates \
|
|
&& rm -rf /var/lib/apt/lists/*
|
|
# Configure cargo target-dir so it can be cached between layers
|
|
RUN mkdir -p /cargo && printf "[build]\ntarget-dir = \"/cargo/target\"\n" > /cargo/config.toml
|
|
# Pre-copy manifests for better caching
|
|
COPY Cargo.toml ./
|
|
COPY crates ./crates
|
|
# Build orchestrator only
|
|
RUN --mount=type=cache,target=/cargo/registry,sharing=locked \
|
|
--mount=type=cache,target=/cargo/git,sharing=locked \
|
|
--mount=type=cache,target=/cargo/target,sharing=locked \
|
|
cargo build --release -p orchestrator --features libvirt && cp /cargo/target/release/orchestrator /orchestrator
|
|
|
|
FROM docker.io/library/debian:bookworm-slim
|
|
# Minimal runtime image with required shared libs for sqlite/postgres and libvirt/qemu tools
|
|
RUN apt-get update \
|
|
&& apt-get install -y --no-install-recommends \
|
|
libsqlite3-0 libpq5 ca-certificates \
|
|
libvirt-clients libvirt0 qemu-utils genisoimage \
|
|
&& rm -rf /var/lib/apt/lists/*
|
|
COPY --from=builder /orchestrator /usr/local/bin/orchestrator
|
|
EXPOSE 50051 8081
|
|
ENTRYPOINT ["/usr/local/bin/orchestrator"]
|