0
0
mirror of https://github.com/neon-mmd/websurfx.git synced 2024-11-21 13:38:21 -05:00

Build arguments to make writing GitHub action for auto releasing new docker images easier (#324)

*  feat: Dockerfile with arch and feature build arguments

* 🛠️ fix: missing issuer certificate error

* ⚙️ refactor: replace `--update` with new `--no-cache` option
This commit is contained in:
leone 2023-10-14 16:18:22 +02:00 committed by GitHub
parent a912ac0724
commit ad297a0a96
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
2 changed files with 35 additions and 26 deletions

View File

@ -6,8 +6,14 @@ description = "An open-source alternative to Searx that provides clean, ad-free,
repository = "https://github.com/neon-mmd/websurfx" repository = "https://github.com/neon-mmd/websurfx"
license = "AGPL-3.0" license = "AGPL-3.0"
[[bin]]
name = "websurfx"
test = true
bench = false
path = "src/bin/websurfx.rs"
[dependencies] [dependencies]
reqwest = {version="0.11.21",features=["json"]} reqwest = {version="0.11.21",default-features = false,features = ["json", "rustls-tls"]}
tokio = {version="1.32.0",features=["rt-multi-thread","macros"]} tokio = {version="1.32.0",features=["rt-multi-thread","macros"]}
serde = {version="1.0.188",features=["derive"]} serde = {version="1.0.188",features=["derive"]}
handlebars = { version = "4.4.0", features = ["dir_source"] } handlebars = { version = "4.4.0", features = ["dir_source"] }

View File

@ -1,40 +1,43 @@
FROM rust:latest AS chef FROM --platform=$BUILDPLATFORM rust:1.73.0-alpine3.18 AS chef
# We only pay the installation cost once, # We only pay the installation cost once,
# it will be cached from the second build onwards # it will be cached from the second build onwards
RUN apk add --no-cache alpine-sdk musl-dev g++ make libcrypto3 libressl-dev upx perl build-base
RUN cargo install cargo-chef --locked RUN cargo install cargo-chef --locked
WORKDIR /app WORKDIR /app
FROM chef AS planner FROM chef AS planner
COPY . . COPY ./Cargo.toml ./Cargo.lock ./
RUN cargo chef prepare --recipe-path recipe.json RUN cargo chef prepare --recipe-path recipe.json
FROM chef AS builder FROM --platform=$BUILDPLATFORM chef AS builder
COPY --from=planner /app/recipe.json recipe.json COPY --from=planner /app/recipe.json recipe.json
# Build dependencies - this is the caching Docker layer! # Specify the cache type to use (memory, redis, hybrid, no-cache)
# Uncomment the line below if you want to use the `hybrid` caching feature. ARG CACHE=memory
# RUN cargo chef cook --release --features redis-cache --recipe-path recipe.json ENV CACHE=${CACHE}
# Comment the line below if you don't want to use the `In-Memory` caching feature. # Cook the dependencies
RUN cargo chef cook --release --recipe-path recipe.json RUN export ARCH=$(uname -m) && \
# Uncomment the line below if you want to use the `no cache` feature. if [ "$CACHE" = "memory" ] ; then cargo chef cook --release --target=$ARCH-unknown-linux-musl --recipe-path recipe.json ; \
# RUN cargo chef cook --release --no-default-features --recipe-path recipe.json else if [ "$CACHE" = "redis" ] ; then cargo chef cook --release --target=$ARCH-unknown-linux-musl --no-default-features --features redis-cache --recipe-path recipe.json ; \
# Uncomment the line below if you want to use the `redis` caching feature. else if [ "$CACHE" = "hybrid" ] ; then cargo chef cook --release --target=$ARCH-unknown-linux-musl --features redis-cache --recipe-path recipe.json ; \
# RUN cargo chef cook --release --no-default-features --features redis-cache --recipe-path recipe.json else if [ "$CACHE" = "no-cache" ] ; then cargo chef cook --release --target=$ARCH-unknown-linux-musl --no-default-features --recipe-path recipe.json ; fi ; fi ; fi ; fi
# Copy the source code and public folder
COPY ./src ./src
COPY ./public ./public
# Build the application
RUN export ARCH=$(uname -m) && \
if [ "$CACHE" = "memory" ] ; then cargo build --release --target=$ARCH-unknown-linux-musl ; \
else if [ "$CACHE" = "redis" ] ; then cargo build --release --target=$ARCH-unknown-linux-musl --no-default-features --features redis-cache ; \
else if [ "$CACHE" = "hybrid" ] ; then cargo build --release --target=$ARCH-unknown-linux-musl --features redis-cache ; \
else if [ "$CACHE" = "no-cache" ] ; then cargo build --release --target=$ARCH-unknown-linux-musl --no-default-features ; fi ; fi ; fi ; fi
# Optimise binary size with UPX
RUN export ARCH=$(uname -m) \
&& upx --lzma --best /app/target/$ARCH-unknown-linux-musl/release/websurfx \
&& cp /app/target/$ARCH-unknown-linux-musl/release/websurfx /usr/local/bin/websurfx
# Build application
COPY . .
# Uncomment the line below if you want to use the `hybrid` caching feature.
# RUN cargo install --path . --features redis-cache
# Comment the line below if you don't want to use the `In-Memory` caching feature.
RUN cargo install --path .
# Uncomment the line below if you want to use the `no cache` feature.
# RUN cargo install --path . --no-default-features
# Uncomment the line below if you want to use the `redis` caching feature.
# RUN cargo install --path . --no-default-features --features redis-cache
# We do not need the Rust toolchain to run the binary! FROM --platform=$BUILDPLATFORM scratch
FROM gcr.io/distroless/cc-debian12
COPY --from=builder /app/public/ /opt/websurfx/public/ COPY --from=builder /app/public/ /opt/websurfx/public/
VOLUME ["/etc/xdg/websurfx/"] VOLUME ["/etc/xdg/websurfx/"]
COPY --from=builder /usr/local/cargo/bin/* /usr/local/bin/ COPY --from=builder /usr/local/bin/websurfx /usr/local/bin/websurfx
CMD ["websurfx"] CMD ["websurfx"]