From dc515cbc8679369754cc3b164927baa420fa69ef Mon Sep 17 00:00:00 2001 From: Tom Trevethan Date: Fri, 2 Aug 2024 14:41:44 +0100 Subject: [PATCH] Update Dockerfile (#81) * Update Dockerfile * Create Rocket2.toml * Update Dockerfile --- Rocket2.toml | 3 +++ token-server/Dockerfile | 41 +++++++++++++++++++++++++++++++---------- 2 files changed, 34 insertions(+), 10 deletions(-) create mode 100644 Rocket2.toml diff --git a/Rocket2.toml b/Rocket2.toml new file mode 100644 index 00000000..732f51f6 --- /dev/null +++ b/Rocket2.toml @@ -0,0 +1,3 @@ +[global] +address = "0.0.0.0" +port = 8001 diff --git a/token-server/Dockerfile b/token-server/Dockerfile index e62903cd..c3b9e549 100644 --- a/token-server/Dockerfile +++ b/token-server/Dockerfile @@ -1,14 +1,35 @@ -FROM rust:1.77.0 +# Use a base image that has the required GLIBC version +FROM debian:bullseye-slim as builder -# Set working directory -WORKDIR /app/lib -COPY ../lib . +# Install Rust, protobuf compiler, and library dependencies +RUN apt-get update && apt-get install -y curl build-essential protobuf-compiler libprotobuf-dev pkg-config libssl-dev +RUN curl --proto '=https' --tlsv1.2 -sSf https://sh.rustup.rs | sh -s -- -y -# Copy the project code -WORKDIR /app -COPY . . +# Set the environment path for Rust +ENV PATH="/root/.cargo/bin:${PATH}" -RUN cargo build --release -EXPOSE 8001 -# Run the application +# Create a working directory +WORKDIR /mercurylayer + +RUN echo "[workspace]\nmembers = [\"token-server\", \"lib\"]" > ./Cargo.toml +COPY ./Cargo.lock ./Cargo.lock + +# Copy the server source code +COPY ./token-server ./token-server +COPY ./lib ./lib +COPY ./Rocket2.toml ./token-server/Rocket.toml + +# Make sure to copy Cargo.lock +COPY ./token-server/Cargo.lock ./token-server/Cargo.lock + +WORKDIR /mercurylayer/token-server + +# RUN cargo build --verbose + +# # Build your Rust project. Since the source files are now present, +# # the Rust compiler should be able to find and compile them. +RUN CARGO_TARGET_DIR=target cargo build --release + +# # Command to run the server by default when the container starts CMD ["cargo", "run", "--bin", "token-server"] +