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:
parent
a912ac0724
commit
ad297a0a96
@ -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"] }
|
||||||
|
53
Dockerfile
53
Dockerfile
@ -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"]
|
||||||
|
Loading…
Reference in New Issue
Block a user