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:
108
Dockerfile
108
Dockerfile
@@ -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"]
|
||||
|
||||
Reference in New Issue
Block a user