# Dockerfile.brancheneinstufung (v2.0 - Final für pyngrok-Ansatz) # Diese Version ist vereinfacht, da ngrok von der Python-Bibliothek verwaltet wird. # 1. Basis-Image FROM python:3.8-slim # 2. System-Abhängigkeiten installieren (von Ihnen bereitgestellt) # Wir behalten 'curl' und 'unzip' bei, da pyngrok sie intern benötigen könnte. RUN apt-get update && apt-get install -y \ wget \ unzip \ gnupg \ ca-certificates \ curl \ 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/* # 3. Google Chrome Stable installieren (von Ihnen bereitgestellt) 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 (Ihre robuste Methode v2) RUN \ LATEST_DRIVER_URL=$(wget -O- --no-check-certificate "https://googlechromelabs.github.io/chrome-for-testing/last-known-good-versions-with-downloads.json" | python -c "import json, sys; \ data = json.load(sys.stdin); \ url = next(d['url'] for d in data['channels']['Stable']['downloads']['chromedriver'] if d['platform'] == 'linux64'); \ print(url)") && \ wget --no-check-certificate -q "${LATEST_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. Python-Abhängigkeiten ZUERST installieren # Dies nutzt den Docker-Cache. Solange sich die requirements.txt nicht ändert, # wird dieser Schritt nicht jedes Mal neu ausgeführt, was den Bauprozess beschleunigt. COPY requirements.txt . # WICHTIG: Stellen Sie sicher, dass 'Flask' und 'pyngrok' in requirements.txt stehen RUN pip install --no-cache-dir -r requirements.txt # 7. Restlichen App-Code kopieren COPY . . # 8. Standard-Startbefehl festlegen # Startet direkt unseren Webserver, der seinerseits ngrok startet. CMD ["python", "app.py"]