[enh] container: use Wolfi OS as base image

Wolfi OS images are specifically designed for container use. Using a specially designed base image for containers not only reduces maintenance burdens, but improves overall experience for developers (fewer packages we have to track) and end users (smaller images).

Discussion here: https://github.com/searxng/searxng/issues/4753
This commit is contained in:
Ivan Gabaldon 2025-05-11 22:07:53 +02:00
parent cd64fb966e
commit 03083f07da
2 changed files with 51 additions and 43 deletions

View File

@ -1,12 +1,10 @@
FROM docker.io/library/python:3.13-slim AS builder FROM cgr.dev/chainguard/wolfi-base:latest AS builder
RUN apt-get update \ RUN apk add --no-cache \
&& apt-get install -y --no-install-recommends \ build-base \
build-essential \ python-3.13-dev \
brotli \ py3-pip \
# uwsgi brotli
libpcre3-dev \
&& rm -rf /var/lib/apt/lists/*
WORKDIR /usr/local/searxng/ WORKDIR /usr/local/searxng/
@ -19,38 +17,40 @@ RUN --mount=type=cache,id=pip,target=/root/.cache/pip python -m venv ./venv \
COPY ./searx/ ./searx/ COPY ./searx/ ./searx/
ARG TIMESTAMP_SETTINGS=0 ARG TIMESTAMP_SETTINGS="0"
ARG TIMESTAMP_UWSGI=0 ARG TIMESTAMP_UWSGI="0"
RUN python -m compileall -q searx \ RUN python -m compileall -q searx \
&& touch -c --date=@$TIMESTAMP_SETTINGS ./searx/settings.yml \ && touch -c --date=@$TIMESTAMP_SETTINGS ./searx/settings.yml \
&& touch -c --date=@$TIMESTAMP_UWSGI ./container/uwsgi.ini \ && touch -c --date=@$TIMESTAMP_UWSGI ./container/uwsgi.ini \
&& find /usr/local/searxng/searx/static \ && find /usr/local/searxng/searx/static \
\( -name '*.html' -o -name '*.css' -o -name '*.js' -o -name '*.svg' -o -name '*.ttf' -o -name '*.eot' \) \ \( -name "*.html" -o -name "*.css" -o -name "*.js" -o -name "*.svg" -o -name "*.ttf" -o -name "*.eot" \) \
-type f -exec gzip -9 -k {} + -exec brotli --best {} + -type f -exec gzip -9 -k {} + -exec brotli --best {} +
ARG SEARXNG_UID=977 ARG SEARXNG_UID="977"
ARG SEARXNG_GID=977 ARG SEARXNG_GID="977"
RUN grep -m1 root /etc/group > /tmp/.searxng.group \ RUN echo "root:x:0:root" >/tmp/.group \
&& grep -m1 root /etc/passwd > /tmp/.searxng.passwd \ && echo "root:x:0:0:root:/usr/local/searxng:/bin/ash" >/tmp/.passwd \
&& echo "searxng:x:$SEARXNG_GID:" >> /tmp/.searxng.group \ && echo "searxng:x:$SEARXNG_GID:searxng" >>/tmp/.group \
&& echo "searxng:x:$SEARXNG_UID:$SEARXNG_GID:searxng:/usr/local/searxng:/bin/bash" >> /tmp/.searxng.passwd && echo "searxng:x:$SEARXNG_UID:$SEARXNG_GID:searxng:/usr/local/searxng:/bin/ash" >>/tmp/.passwd
FROM docker.io/library/python:3.13-slim FROM scratch AS dist
RUN apt-get update \ # Prepare base image
&& apt-get install -y --no-install-recommends \ COPY --from=builder /tmp/.passwd /etc/passwd
COPY --from=builder /tmp/.group /etc/group
COPY --chown=root:root --from=cgr.dev/chainguard/wolfi-base:latest / /
COPY --chown=root:root --from=builder /tmp/.passwd /etc/passwd
COPY --chown=root:root --from=builder /tmp/.group /etc/group
RUN rm -rf /root/ /home/
RUN apk add --no-cache \
python-3.13 \
# healthcheck # healthcheck
wget \ wget \
# uwsgi # uwsgi
libpcre3 \ mailcap
libxml2 \
mailcap \
&& rm -rf /var/lib/apt/lists/*
COPY --chown=root:root --from=builder /tmp/.searxng.passwd /etc/passwd
COPY --chown=root:root --from=builder /tmp/.searxng.group /etc/group
ARG LABEL_DATE="0001-01-01T00:00:00Z" ARG LABEL_DATE="0001-01-01T00:00:00Z"
ARG GIT_URL="unspecified" ARG GIT_URL="unspecified"
@ -65,30 +65,37 @@ COPY --chown=searxng:searxng --from=builder /usr/local/searxng/searx/ ./searx/
COPY --chown=searxng:searxng ./container/ ./container/ COPY --chown=searxng:searxng ./container/ ./container/
LABEL org.opencontainers.image.authors="searxng <$GIT_URL>" \ LABEL org.opencontainers.image.authors="searxng <$GIT_URL>" \
org.opencontainers.image.created=$LABEL_DATE \ org.opencontainers.image.created="$LABEL_DATE" \
org.opencontainers.image.description="A privacy-respecting, hackable metasearch engine" \ org.opencontainers.image.description="A privacy-respecting, hackable metasearch engine" \
org.opencontainers.image.documentation="https://github.com/searxng/searxng-docker" \ org.opencontainers.image.documentation="https://github.com/searxng/searxng-docker" \
org.opencontainers.image.licenses="AGPL-3.0-or-later" \ org.opencontainers.image.licenses="AGPL-3.0-or-later" \
org.opencontainers.image.revision=$LABEL_VCS_REF \ org.opencontainers.image.revision="$LABEL_VCS_REF" \
org.opencontainers.image.source=$LABEL_VCS_URL \ org.opencontainers.image.source="$LABEL_VCS_URL" \
org.opencontainers.image.title="searxng" \ org.opencontainers.image.title="searxng" \
org.opencontainers.image.url=$LABEL_VCS_URL \ org.opencontainers.image.url="$LABEL_VCS_URL" \
org.opencontainers.image.version=$SEARXNG_GIT_VERSION org.opencontainers.image.version="$SEARXNG_GIT_VERSION"
ENV CONFIG_PATH=/etc/searxng \ # Image specific environment variables
DATA_PATH=/var/cache/searxng ENV PATH="/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin" \
SSL_CERT_FILE="/etc/ssl/certs/ca-certificates.crt" \
HISTFILE="/dev/null" \
CONFIG_PATH="/etc/searxng" \
DATA_PATH="/var/cache/searxng"
ENV SEARXNG_VERSION=$SEARXNG_GIT_VERSION \ # SearXNG specific environment variables
INSTANCE_NAME=searxng \ ENV SEARXNG_VERSION="$SEARXNG_GIT_VERSION" \
INSTANCE_NAME="searxng" \
AUTOCOMPLETE="" \ AUTOCOMPLETE="" \
BASE_URL="" \ BASE_URL="" \
BIND_ADDRESS=[::]:8080 \ BIND_ADDRESS="[::]:8080" \
MORTY_KEY="" \ SEARXNG_SETTINGS_PATH="$CONFIG_PATH/settings.yml" \
MORTY_URL="" \ UWSGI_SETTINGS_PATH="$CONFIG_PATH/uwsgi.ini" \
SEARXNG_SETTINGS_PATH=$CONFIG_PATH/settings.yml \ UWSGI_WORKERS="%k" \
UWSGI_SETTINGS_PATH=$CONFIG_PATH/uwsgi.ini \ UWSGI_THREADS="4"
UWSGI_WORKERS=%k \
UWSGI_THREADS=4 # Volume ownership
RUN mkdir -p $CONFIG_PATH $DATA_PATH \
&& chown -R searxng:searxng $CONFIG_PATH $DATA_PATH
VOLUME $CONFIG_PATH VOLUME $CONFIG_PATH
VOLUME $DATA_PATH VOLUME $DATA_PATH

View File

@ -71,6 +71,7 @@ patch_searxng_settings() {
"${CONF}" "${CONF}"
} }
# FIXME: Always use "searxng:searxng" ownership
update_conf() { update_conf() {
FORCE_CONF_UPDATE=$1 FORCE_CONF_UPDATE=$1
CONF="$2" CONF="$2"