From 323084b5c2a122f326a88883853e11c6a9f5e5ec Mon Sep 17 00:00:00 2001 From: SadlyNotSappho Date: Tue, 12 Dec 2023 12:16:09 -0800 Subject: [PATCH] get docker almost working --- .gitignore | 4 ++- Dockerfile | 68 ++++++++++++++++++++++++++++++++++++++ README.md | 6 +++- db/password.txt.example | 1 + docker-compose.yml.example | 57 ++++++++++++++++++++++++++++++++ src/main.rs | 4 +-- 6 files changed, 135 insertions(+), 5 deletions(-) create mode 100644 Dockerfile create mode 100644 db/password.txt.example create mode 100644 docker-compose.yml.example diff --git a/.gitignore b/.gitignore index c1cdd55..5afd3f7 100644 --- a/.gitignore +++ b/.gitignore @@ -1,2 +1,4 @@ /target -Rocket.toml +docker-compose.yml +db/password.txt + diff --git a/Dockerfile b/Dockerfile new file mode 100644 index 0000000..775490c --- /dev/null +++ b/Dockerfile @@ -0,0 +1,68 @@ +# syntax=docker/dockerfile:1 + +# Comments are provided throughout this file to help you get started. +# If you need more help, visit the Dockerfile reference guide at +# https://docs.docker.com/engine/reference/builder/ + +################################################################################ +# Create a stage for building the application. + +ARG RUST_VERSION=1.74.0 +ARG APP_NAME=fossil +FROM rust:${RUST_VERSION}-slim-bullseye AS build +ARG APP_NAME +WORKDIR /app + +# Build the application. +# Leverage a cache mount to /usr/local/cargo/registry/ +# for downloaded dependencies and a cache mount to /app/target/ for +# compiled dependencies which will speed up subsequent builds. +# Leverage a bind mount to the src directory to avoid having to copy the +# source code into the container. Once built, copy the executable to an +# output directory before the cache mounted /app/target is unmounted. +RUN --mount=type=bind,source=src,target=src \ + --mount=type=bind,source=Cargo.toml,target=Cargo.toml \ + --mount=type=bind,source=Cargo.lock,target=Cargo.lock \ + --mount=type=cache,target=/app/target/ \ + --mount=type=cache,target=/usr/local/cargo/registry/ \ + --mount=type=bind,source=migrations,target=migrations \ + <) -> &'static str { async fn main() { let _rocket = rocket::build() .mount("/", routes![hello, get_book, delay, login, logout]) - .mount("/login", FileServer::from("./web")) + .mount("/login", FileServer::from("/srv/web")) .launch() .await .unwrap();