Dockerfile 3.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107
  1. FROM cgr.dev/chainguard/wolfi-base:latest AS builder
  2. RUN apk add --no-cache \
  3. build-base \
  4. python-3.13-dev \
  5. py3-pip \
  6. brotli
  7. WORKDIR /usr/local/searxng/
  8. COPY ./requirements.txt ./requirements.txt
  9. RUN --mount=type=cache,id=pip,target=/root/.cache/pip python -m venv ./venv \
  10. && . ./venv/bin/activate \
  11. && pip install -r requirements.txt \
  12. && pip install "uwsgi~=2.0"
  13. COPY ./searx/ ./searx/
  14. ARG TIMESTAMP_SETTINGS="0"
  15. ARG TIMESTAMP_UWSGI="0"
  16. RUN python -m compileall -q searx \
  17. && touch -c --date=@$TIMESTAMP_SETTINGS ./searx/settings.yml \
  18. && touch -c --date=@$TIMESTAMP_UWSGI ./container/uwsgi.ini \
  19. && find /usr/local/searxng/searx/static \
  20. \( -name "*.html" -o -name "*.css" -o -name "*.js" -o -name "*.svg" -o -name "*.ttf" -o -name "*.eot" \) \
  21. -type f -exec gzip -9 -k {} + -exec brotli --best {} +
  22. ARG SEARXNG_UID="977"
  23. ARG SEARXNG_GID="977"
  24. RUN echo "root:x:0:root" >/tmp/.group \
  25. && echo "root:x:0:0:root:/usr/local/searxng:/bin/ash" >/tmp/.passwd \
  26. && echo "searxng:x:$SEARXNG_GID:searxng" >>/tmp/.group \
  27. && echo "searxng:x:$SEARXNG_UID:$SEARXNG_GID:searxng:/usr/local/searxng:/bin/ash" >>/tmp/.passwd
  28. FROM scratch AS dist
  29. # Prepare base image
  30. COPY --from=builder /tmp/.passwd /etc/passwd
  31. COPY --from=builder /tmp/.group /etc/group
  32. COPY --chown=root:root --from=cgr.dev/chainguard/wolfi-base:latest / /
  33. COPY --chown=root:root --from=builder /tmp/.passwd /etc/passwd
  34. COPY --chown=root:root --from=builder /tmp/.group /etc/group
  35. RUN rm -rf /root/ /home/
  36. RUN apk add --no-cache \
  37. python-3.13 \
  38. # healthcheck
  39. wget \
  40. # uwsgi
  41. mailcap
  42. ARG LABEL_DATE="0001-01-01T00:00:00Z"
  43. ARG GIT_URL="unspecified"
  44. ARG SEARXNG_GIT_VERSION="unspecified"
  45. ARG LABEL_VCS_REF="unspecified"
  46. ARG LABEL_VCS_URL="unspecified"
  47. WORKDIR /usr/local/searxng/
  48. COPY --chown=searxng:searxng --from=builder /usr/local/searxng/venv/ ./venv/
  49. COPY --chown=searxng:searxng --from=builder /usr/local/searxng/searx/ ./searx/
  50. COPY --chown=searxng:searxng ./container/ ./container/
  51. LABEL org.opencontainers.image.authors="searxng <$GIT_URL>" \
  52. org.opencontainers.image.created="$LABEL_DATE" \
  53. org.opencontainers.image.description="A privacy-respecting, hackable metasearch engine" \
  54. org.opencontainers.image.documentation="https://github.com/searxng/searxng-docker" \
  55. org.opencontainers.image.licenses="AGPL-3.0-or-later" \
  56. org.opencontainers.image.revision="$LABEL_VCS_REF" \
  57. org.opencontainers.image.source="$LABEL_VCS_URL" \
  58. org.opencontainers.image.title="searxng" \
  59. org.opencontainers.image.url="$LABEL_VCS_URL" \
  60. org.opencontainers.image.version="$SEARXNG_GIT_VERSION"
  61. # Image specific environment variables
  62. ENV PATH="/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin" \
  63. SSL_CERT_FILE="/etc/ssl/certs/ca-certificates.crt" \
  64. HISTFILE="/dev/null" \
  65. CONFIG_PATH="/etc/searxng" \
  66. DATA_PATH="/var/cache/searxng"
  67. # SearXNG specific environment variables
  68. ENV SEARXNG_VERSION="$SEARXNG_GIT_VERSION" \
  69. INSTANCE_NAME="searxng" \
  70. AUTOCOMPLETE="" \
  71. BASE_URL="" \
  72. BIND_ADDRESS="[::]:8080" \
  73. SEARXNG_SETTINGS_PATH="$CONFIG_PATH/settings.yml" \
  74. UWSGI_SETTINGS_PATH="$CONFIG_PATH/uwsgi.ini" \
  75. UWSGI_WORKERS="%k" \
  76. UWSGI_THREADS="4"
  77. # Volume ownership
  78. RUN mkdir -p $CONFIG_PATH $DATA_PATH \
  79. && chown -R searxng:searxng $CONFIG_PATH $DATA_PATH
  80. VOLUME $CONFIG_PATH
  81. VOLUME $DATA_PATH
  82. EXPOSE 8080
  83. HEALTHCHECK CMD wget --quiet --tries=1 --spider http://localhost:8080/healthz || exit 1
  84. ENTRYPOINT ["/usr/local/searxng/container/docker-entrypoint.sh"]