Files
Brancheneinstufung2/Dockerfile.brancheneinstufung

66 lines
2.5 KiB
Docker

# 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"]