0
0
mirror of https://github.com/neon-mmd/websurfx.git synced 2025-01-02 09:38:22 -05:00
websurfx/Dockerfile

41 lines
1.8 KiB
Docker
Raw Normal View History

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"]