feat: Dockerfile für das Market Intelligence Backend hinzufügen

Erstellt ein mehrstufiges Dockerfile, um die Python- und Node.js-Umgebung für den Backend-Service zu kapseln. Dies soll die 'cygrpc'-Kompatibilitätsprobleme durch eine saubere, kontrollierte Build-Umgebung lösen.
This commit is contained in:
2025-12-21 01:53:20 +00:00
parent a347620d02
commit c42b968c0d

View File

@@ -1,60 +1,60 @@
# 1. Basis-Image
FROM python:3.8-slim
# Dockerfile für das Market Intelligence Backend
# Nutzt ein Node.js Image als Basis und installiert Python und alle Abhängigkeiten.
# 2. System-Abhängigkeiten installieren (für Chrome etc.)
RUN apt-get update && apt-get install -y \
wget \
unzip \
gnupg \
ca-certificates \
fonts-liberation \
libasound2 \
libatk-bridge2.0-0 \
libatk1.0-0 \
libcups2 \
libdbus-1-3 \
libgdk-pixbuf2.0-0 \
libnspr4 \
libnss3 \
libx11-xcb1 \
libxcomposite1 \
libxdamage1 \
libxrandr2 \
xdg-utils \
--no-install-recommends && \
rm -rf /var/lib/apt/lists/*
# Phase 1: Build Stage für Python-Abhängigkeiten
FROM node:20-slim as python-deps
# 3. Google Chrome Stable installieren
RUN wget -q -O - https://dl.google.com/linux/linux_signing_key.pub | apt-key add - && \
echo "deb [arch=amd64] http://dl.google.com/linux/chrome/deb/ stable main" > /etc/apt/sources.list.d/google-chrome.list && \
apt-get update && \
apt-get install -y google-chrome-stable --no-install-recommends && \
rm -rf /var/lib/apt/lists/*
# 4. Passenden Chromedriver installieren (FINALE METHODE MIT VERSIONSABGLEICH)
# Liest die installierte Chrome-Version aus und sucht den exakt passenden Treiber.
RUN \
export CHROME_VERSION=$(google-chrome --version | cut -f 3 -d ' ') && \
DRIVER_URL=$(wget -O- --no-check-certificate "https://googlechromelabs.github.io/chrome-for-testing/known-good-versions-with-downloads.json" | python -c "import os, json, sys; \
versions = json.load(sys.stdin)['versions']; \
target_version = os.environ['CHROME_VERSION']; \
v_entry = next(v for v in versions if v['version'] == target_version); \
url = next(d['url'] for d in v_entry['downloads']['chromedriver'] if d['platform'] == 'linux64'); \
print(url)") && \
wget --no-check-certificate -q "${DRIVER_URL}" -O /tmp/chromedriver.zip && \
unzip /tmp/chromedriver.zip -d /usr/local/bin/ && \
mv /usr/local/bin/chromedriver-linux64/chromedriver /usr/local/bin/ && \
rm -rf /tmp/chromedriver.zip /usr/local/bin/chromedriver-linux64 && \
chmod +x /usr/local/bin/chromedriver
# 5. App-Verzeichnis einrichten
WORKDIR /app
# 6. Anwendungsdateien kopieren
COPY . .
# Systemabhängigkeiten für Python-Builds (insbesondere grpcio)
RUN apt-get update && apt-get install -y \
python3 \
python3-pip \
python3-venv \
python3-dev \
build-essential \
gcc \
&& rm -rf /var/lib/apt/lists/*
# 7. Python-Abhängigkeiten installieren
RUN pip3 install --no-cache-dir -r requirements.txt
# Virtuelle Umgebung erstellen und aktivieren
RUN python3 -m venv .venv
ENV PATH="/app/.venv:$PATH"
# 8. Standard-Startbefehl festlegen
CMD ["python3", "scrape_fotograf.py"]
# Python-Abhängigkeiten kopieren und installieren
COPY requirements.txt .
RUN pip install --no-cache-dir -r requirements.txt
# Phase 2: Final Stage
FROM node:20-slim
WORKDIR /app
# Systemabhängigkeiten für den Runtime-Betrieb
RUN apt-get update && apt-get install -y \
python3 \
# Optional: weitere Runtime-Abhängigkeiten hier hinzufügen, falls benötigt
&& rm -rf /var/lib/apt/lists/*
# Venv aus der Build Stage kopieren
COPY --from=python-deps /app/.venv ./.venv
ENV PATH="/app/.venv:$PATH"
# Node.js-Anwendung und Python-Skript kopieren
COPY general-market-intelligence/package*.json ./general-market-intelligence/
COPY general-market-intelligence/server.cjs ./general-market-intelligence/
COPY general-market-intelligence/.gitignore ./general-market-intelligence/
COPY market_intel_orchestrator.py .
COPY gemini_api_key.txt .
COPY tmp tmp/
# Node.js-Abhängigkeiten installieren
RUN cd general-market-intelligence && npm install --no-cache
# Umgebungsvariablen setzen (API Key wird aus Datei geladen, hier nur als Beispiel)
# ENV GEMINI_API_KEY="your_gemini_api_key_here" # Besser: Als bind mount oder Secret managen
# Port für die Node.js API-Brücke
EXPOSE 3001
# Startbefehl für den Node.js API-Brücke-Server
CMD ["node", "general-market-intelligence/server.cjs"]