# This file builds the server only, and does not copy the frontend build. # This is useful for frontend development, as it allows you to run the frontend # with an actual backend. # Note that this runs the server in debug mode, which is slower than release mode. # Builds the server in an isolated stage # We use musl to get a truly static binary # that runs cleanly without depending on glibc. FROM docker.io/rust:latest as builder WORKDIR /build ADD ./server /build RUN apt update RUN apt install musl musl-dev musl-tools -y RUN rustup target add x86_64-unknown-linux-musl # Note that '--release' is missing here, so we build in debug mode RUN cargo build --target x86_64-unknown-linux-musl # Final stage, copy the server binary and the frontend build # This stage is the actual container, and is based on alpine # a minimal linux distribution resulting in a small image. FROM docker.io/alpine:latest as runner # Add a non-root user for running the server RUN addgroup -S user && adduser -S user -G user WORKDIR /runner # Copy the server binary and the public directory, note the debug binary COPY --from=builder /build/target/x86_64-unknown-linux-musl/debug/server /runner/server # Make sure the user can access the files RUN chown -R user:user /runner USER user # Run the server EXPOSE 8080 CMD ["./server"]