51 lines
1.8 KiB
Text
51 lines
1.8 KiB
Text
# Note that building this requires the proper build context
|
|
|
|
# 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
|
|
RUN apt update
|
|
RUN apt install musl musl-dev musl-tools -y
|
|
RUN rustup target add x86_64-unknown-linux-musl
|
|
|
|
# Some hacks to make podman cache build deps, see:
|
|
# https://whitfin.io/blog/speeding-up-rust-docker-builds/
|
|
RUN cargo new build-container
|
|
WORKDIR /build-container
|
|
COPY server/Cargo.toml server/Cargo.lock ./
|
|
RUN cargo build --target x86_64-unknown-linux-musl
|
|
RUN rm src/*.rs
|
|
ADD server /build-container
|
|
|
|
# Make sure sqlx reads from .sqlx directory
|
|
ENV SQLX_OFFLINE true
|
|
|
|
# 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-container/target/x86_64-unknown-linux-musl/debug/server /runner/server
|
|
RUN mkdir /runner/public
|
|
RUN echo "Debug build!" > /runner/public/index.html
|
|
|
|
# Make sure the user can access the files
|
|
RUN chown -R user:user /runner
|
|
USER user
|
|
|
|
# Run the server
|
|
EXPOSE 8080
|
|
CMD ["./server"]
|