fix(searxng): Env-Substitution über Python statt !env-YAML-Tag
All checks were successful
Build & Publish Docker Image / build-and-push (push) Successful in 1m15s
All checks were successful
Build & Publish Docker Image / build-and-push (push) Successful in 1m15s
SearXNG v2026 kennt keinen !env-YAML-Constructor — Container crasht
mit „could not determine a constructor for the tag '!env'". Fix: wir
mounten settings.yml read-only auf /config-src, und ein Entrypoint-Hook
schreibt beim Start eine expandierte Fassung nach /etc/searxng/settings.yml
(mit os.path.expandvars — Python ist im Image, envsubst fehlt).
- settings.yml: api_key nutzt jetzt ${BRAVE_API_KEY} statt !env.
- docker-compose.prod.yml: searxng-Container bekommt entrypoint-
Override, reicht BRAVE_API_KEY + SEARXNG_SECRET als Env durch und
expandiert das YAML vor exec.
Leerer Key ist weiterhin ok — Brave antwortet dann mit 401, andere
Engines bleiben unberührt.
Co-Authored-By: Claude Opus 4.7 (1M context) <noreply@anthropic.com>
This commit is contained in:
@@ -33,14 +33,31 @@ services:
|
|||||||
searxng:
|
searxng:
|
||||||
# Absichtlich nur intern erreichbar — keine Traefik-Labels, kein externer Port.
|
# Absichtlich nur intern erreichbar — keine Traefik-Labels, kein externer Port.
|
||||||
image: searxng/searxng:latest
|
image: searxng/searxng:latest
|
||||||
|
# settings.yml wird read-only gemountet und beim Start in eine beschreib-
|
||||||
|
# bare /etc/searxng-Kopie expandiert (${…}-Platzhalter → ENV-Werte),
|
||||||
|
# damit der Brave-API-Key aus .env eingesetzt werden kann, ohne ihn im
|
||||||
|
# Repo zu pflegen. SearXNG selbst hat kein !env-Tag, daher machen wir
|
||||||
|
# es per Python im Entrypoint-Hook. Das SearXNG-Image hat Python bereits
|
||||||
|
# installiert; envsubst fehlt im Alpine-Base.
|
||||||
volumes:
|
volumes:
|
||||||
- ./searxng:/etc/searxng
|
- ./searxng:/config-src:ro
|
||||||
environment:
|
environment:
|
||||||
- BASE_URL=http://searxng:8080/
|
- BASE_URL=http://searxng:8080/
|
||||||
- INSTANCE_NAME=kochwas-search
|
- INSTANCE_NAME=kochwas-search
|
||||||
# Brave Search API-Key aus .env (auf dem Pi gepflegt, nicht im Repo).
|
# Brave Search API-Key aus .env (auf dem Pi gepflegt, nicht im Repo).
|
||||||
# Leer oder fehlend → brave-Engine ist im settings.yml disabled/default.
|
# Leer oder fehlend → brave-Engine antwortet mit 401, andere Engines
|
||||||
|
# laufen normal weiter.
|
||||||
- BRAVE_API_KEY=${BRAVE_API_KEY:-}
|
- BRAVE_API_KEY=${BRAVE_API_KEY:-}
|
||||||
|
- SEARXNG_SECRET=${SEARXNG_SECRET:-dev-secret-change-in-prod}
|
||||||
|
entrypoint:
|
||||||
|
- /bin/sh
|
||||||
|
- -c
|
||||||
|
- |
|
||||||
|
set -e
|
||||||
|
mkdir -p /etc/searxng
|
||||||
|
python3 -c "import os,sys; sys.stdout.write(os.path.expandvars(open('/config-src/settings.yml').read()))" > /etc/searxng/settings.yml
|
||||||
|
exec /usr/local/searxng/dockerfiles/docker-entrypoint.sh "$@"
|
||||||
|
- --
|
||||||
restart: unless-stopped
|
restart: unless-stopped
|
||||||
networks:
|
networks:
|
||||||
- internal
|
- internal
|
||||||
|
|||||||
@@ -46,7 +46,10 @@ engines:
|
|||||||
shortcut: br
|
shortcut: br
|
||||||
categories: [general, web]
|
categories: [general, web]
|
||||||
timeout: 6.0
|
timeout: 6.0
|
||||||
api_key: !env BRAVE_API_KEY
|
# Wert wird beim Container-Start durch Python-os.path.expandvars aus der
|
||||||
|
# BRAVE_API_KEY-Env-Variable eingesetzt (siehe docker-compose.prod.yml
|
||||||
|
# entrypoint-Override). SearXNG selbst hat kein !env-Tag.
|
||||||
|
api_key: "${BRAVE_API_KEY}"
|
||||||
disabled: false
|
disabled: false
|
||||||
|
|
||||||
# DuckDuckGo: Standard-Scraper, 3s-Default war zu knapp. Bleibt als Fallback,
|
# DuckDuckGo: Standard-Scraper, 3s-Default war zu knapp. Bleibt als Fallback,
|
||||||
|
|||||||
Reference in New Issue
Block a user