FROM rust:latest AS chef | |
# We only pay the installation cost once, | |
# it will be cached from the second build onwards | |
RUN cargo install cargo-chef --locked | |
WORKDIR /app | |
FROM chef AS planner | |
COPY . . | |
RUN cargo chef prepare --recipe-path recipe.json | |
FROM chef AS builder | |
COPY --from=planner /app/recipe.json recipe.json | |
# Build dependencies - this is the caching Docker layer! | |
# Uncomment the line below if you want to use the `hybrid` caching feature. | |
# RUN cargo chef cook --release --features redis-cache --recipe-path recipe.json | |
# Comment the line below if you don't want to use the `In-Memory` caching feature. | |
RUN cargo chef cook --release --recipe-path recipe.json | |
# Uncomment the line below if you want to use the `no cache` feature. | |
# RUN cargo chef cook --release --no-default-features --recipe-path recipe.json | |
# Uncomment the line below if you want to use the `redis` caching feature. | |
# RUN cargo chef cook --release --no-default-features --features redis-cache --recipe-path recipe.json | |
# Build application | |
COPY . . | |
# Uncomment the line below if you want to use the `hybrid` caching feature. | |
# RUN cargo install --path . --features redis-cache | |
# Comment the line below if you don't want to use the `In-Memory` caching feature. | |
RUN cargo install --path . | |
# Uncomment the line below if you want to use the `no cache` feature. | |
# RUN cargo install --path . --no-default-features | |
# Uncomment the line below if you want to use the `redis` caching feature. | |
# RUN cargo install --path . --no-default-features --features redis-cache | |
# We do not need the Rust toolchain to run the binary! | |
FROM gcr.io/distroless/cc-debian12 | |
COPY --from=builder /app/public/ /opt/websurfx/public/ | |
VOLUME ["/etc/xdg/websurfx/"] | |
COPY --from=builder /usr/local/cargo/bin/* /usr/local/bin/ | |
CMD ["websurfx"] | |