mirror of
https://git.verdigado.com/NB-Public/simple-wkd.git
synced 2024-10-30 03:05:51 +01:00
Add rust buildcache to dockerfile
This commit is contained in:
parent
344a31860a
commit
9f4c5fbc05
1 changed files with 25 additions and 1 deletions
26
Dockerfile
26
Dockerfile
|
@ -1,7 +1,26 @@
|
||||||
FROM rust:1.68-alpine3.17 AS bin-builder
|
FROM rust:1.68-alpine3.17 AS bin-builder
|
||||||
|
|
||||||
COPY backend .
|
# Install dependencies
|
||||||
RUN apk add --no-cache openssl-dev openssl-libs-static musl-dev
|
RUN apk add --no-cache openssl-dev openssl-libs-static musl-dev
|
||||||
|
|
||||||
|
# This will build all dependencies and store them in docker's cache.
|
||||||
|
# This way, it won't be necessary to recompile everything everytime
|
||||||
|
COPY backend/Cargo.toml .
|
||||||
|
COPY backend/Cargo.lock .
|
||||||
|
RUN echo '[[bin]]' >> Cargo.toml && \
|
||||||
|
echo 'name = "cache"' >> Cargo.toml && \
|
||||||
|
echo 'path = "cache.rs"' >> Cargo.toml && \
|
||||||
|
echo 'fn main() {eprintln!("Caching crates...")}' > cache.rs && \
|
||||||
|
export OPENSSL_STATIC=1 && \
|
||||||
|
export OPENSSL_LIB_DIR=/usr/lib && \
|
||||||
|
export OPENSSL_INCLUDE_DIR=/usr/include/openssl && \
|
||||||
|
cargo build --release
|
||||||
|
RUN rm cache.rs && \
|
||||||
|
rm Cargo.toml
|
||||||
|
|
||||||
|
# Build wimple-wkd
|
||||||
|
COPY backend/Cargo.toml .
|
||||||
|
COPY backend/src src
|
||||||
RUN export OPENSSL_STATIC=1 && \
|
RUN export OPENSSL_STATIC=1 && \
|
||||||
export OPENSSL_LIB_DIR=/usr/lib &&\
|
export OPENSSL_LIB_DIR=/usr/lib &&\
|
||||||
export OPENSSL_INCLUDE_DIR=/usr/include/openssl && \
|
export OPENSSL_INCLUDE_DIR=/usr/include/openssl && \
|
||||||
|
@ -10,16 +29,21 @@ RUN export OPENSSL_STATIC=1 && \
|
||||||
|
|
||||||
FROM node:19-alpine3.17 AS webpage-builder
|
FROM node:19-alpine3.17 AS webpage-builder
|
||||||
|
|
||||||
|
# Build website
|
||||||
COPY website .
|
COPY website .
|
||||||
RUN npm install -g pnpm && \
|
RUN npm install -g pnpm && \
|
||||||
pnpm install && \
|
pnpm install && \
|
||||||
pnpm run build
|
pnpm run build
|
||||||
COPY assets assets
|
COPY assets assets
|
||||||
|
|
||||||
|
# Move website in templates folder
|
||||||
RUN mv dist assets/webpage
|
RUN mv dist assets/webpage
|
||||||
|
|
||||||
|
|
||||||
FROM alpine:3.17
|
FROM alpine:3.17
|
||||||
|
|
||||||
|
# Put everything together
|
||||||
|
# It uses user `wkd` for added security
|
||||||
WORKDIR /wkd
|
WORKDIR /wkd
|
||||||
RUN adduser --no-create-home --disabled-password wkd && \
|
RUN adduser --no-create-home --disabled-password wkd && \
|
||||||
chown -R wkd:wkd /wkd
|
chown -R wkd:wkd /wkd
|
||||||
|
|
Loading…
Reference in a new issue