Spaces:
Sleeping
Sleeping
File size: 2,065 Bytes
93d4490 4cbb647 93d4490 4cbb647 93d4490 c7da71a 93d4490 17ddbdc | 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 | # ÉTAPE 1: Image de base
FROM python:3.11-slim
# ÉTAPE 2: Configuration et Dossier de travail
# Ligne supprimée (ENV PORT 8080) pour laisser Hugging Face Spaces injecter le port correct ($PORT, généralement 7860).
ENV FLASK_APP app.py
ENV GUNICORN_WORKERS 4
ENV GUNICORN_THREADS 2
# Création et utilisation du répertoire /app
WORKDIR /app
# ÉTAPE 3: Installation des dépendances (OPTIMISATION CACHING)
# Copie uniquement de requirements.txt pour mettre en cache l'installation
COPY requirements.txt .
# Installation des dépendances du système (eSpeak, PortAudio) et Python
RUN apt-get update && \
# SUPPRESSION: Retrait de l'ancienne version d'espeak et des données
apt-get remove -y espeak libespeak1 espeak-data || echo "espeak non installé, continuer" && \
# AJOUT: Installation d'eSpeak-NG et libportaudio2 (pour la compatibilité)
apt-get install -y espeak-ng libportaudio2 && \
pip install --no-cache-dir -r requirements.txt \
&& rm requirements.txt
# ÉTAPE 4: Copie de l'Application et des Fichiers
# Nous copions tous les fichiers de l'application et nous assurons que
# l'utilisateur 'user' en est le propriétaire.
# CORRECTION MAJEURE : Ajout du dossier templates
# Ceci est l'étape essentielle pour que Flask trouve vos fichiers HTML
COPY templates /app/templates
# Copie des autres fichiers (y compris app.py, votre point d'entrée)
COPY app.py .
COPY tts_engine.py .
COPY gunicorn.conf.py .
# Copie du script d'entrée
COPY entrypoint.sh .
# NOUVEAU: CORRECTION DES FINS DE LIGNE (Résout 'exec ./entrypoint.sh: no such file or directory')
# Supprime le caractère de retour chariot (\r)
RUN sed -i 's/\r$//' entrypoint.sh
# Le rendre exécutable
RUN chmod +x entrypoint.sh
# ÉTAPE 5: Sécurité et Exécution
# Création et bascule vers l'utilisateur non-root ('user') pour la sécurité
RUN useradd -ms /bin/bash user
RUN chown -R user:user /app
USER user
# Indique à Docker que le conteneur écoute sur ce port
EXPOSE $PORT
# Lance l'application via le script d'entrée
CMD ["./entrypoint.sh"] |