Spaces:
Sleeping
Sleeping
Update Dockerfile
Browse files- Dockerfile +12 -10
Dockerfile
CHANGED
|
@@ -1,7 +1,8 @@
|
|
| 1 |
-
# Utilise une image de base Python stable
|
| 2 |
FROM python:3.9-slim-buster
|
| 3 |
|
| 4 |
-
# Crée un utilisateur non-root pour des raisons de sécurité
|
|
|
|
| 5 |
RUN useradd -m -u 1000 user
|
| 6 |
USER user
|
| 7 |
|
|
@@ -9,23 +10,24 @@ USER user
|
|
| 9 |
# Tous les fichiers copiés seront relatifs à ce répertoire
|
| 10 |
WORKDIR /app
|
| 11 |
|
|
|
|
|
|
|
|
|
|
| 12 |
# Copie le fichier requirements.txt et installe les dépendances
|
|
|
|
| 13 |
# Ceci est fait en premier pour tirer parti de la mise en cache de Docker
|
| 14 |
-
# Si les dépendances ne changent pas, cette couche ne sera pas reconstruite
|
| 15 |
COPY --chown=user requirements.txt .
|
| 16 |
-
RUN pip install --no-cache-dir --upgrade -r requirements.txt
|
| 17 |
|
| 18 |
# Copie le reste de ton code d'application (main.py, etc.)
|
| 19 |
-
# Assure-toi que main.py est bien à la racine du dossier que tu copies
|
| 20 |
COPY --chown=user . /app
|
| 21 |
|
| 22 |
# Expose le port sur lequel ton API FastAPI écoute
|
| 23 |
-
#
|
| 24 |
-
# mais pour une API Docker pure, tu peux définir le port que tu veux.
|
| 25 |
-
# Cependant, 7860 est souvent le plus simple car c'est celui que Hugging Face attend implicitement.
|
| 26 |
-
# Si ton API écoute sur 8010 comme dans main.py, utilise 8010 ici.
|
| 27 |
EXPOSE 8010
|
| 28 |
|
| 29 |
# Commande pour lancer l'application avec Uvicorn
|
| 30 |
-
# app
|
|
|
|
| 31 |
CMD ["uvicorn", "main:app", "--host", "0.0.0.0", "--port", "8010"]
|
|
|
|
| 1 |
+
# Utilise une image de base Python stable (slim-buster est plus légère)
|
| 2 |
FROM python:3.9-slim-buster
|
| 3 |
|
| 4 |
+
# Crée un utilisateur non-root pour des raisons de sécurité
|
| 5 |
+
# C'est une bonne pratique qui était déjà dans tes instructions Hugging Face
|
| 6 |
RUN useradd -m -u 1000 user
|
| 7 |
USER user
|
| 8 |
|
|
|
|
| 10 |
# Tous les fichiers copiés seront relatifs à ce répertoire
|
| 11 |
WORKDIR /app
|
| 12 |
|
| 13 |
+
# Ajoute le répertoire ~/.local/bin au PATH pour s'assurer que les exécutables pip sont trouvés
|
| 14 |
+
ENV PATH="/home/user/.local/bin:$PATH"
|
| 15 |
+
|
| 16 |
# Copie le fichier requirements.txt et installe les dépendances
|
| 17 |
+
# IMPORTANT : Ajout de --user pour que uvicorn soit installé dans ~/.local/bin
|
| 18 |
# Ceci est fait en premier pour tirer parti de la mise en cache de Docker
|
|
|
|
| 19 |
COPY --chown=user requirements.txt .
|
| 20 |
+
RUN pip install --no-cache-dir --upgrade -r requirements.txt --user
|
| 21 |
|
| 22 |
# Copie le reste de ton code d'application (main.py, etc.)
|
| 23 |
+
# Assure-toi que main.py est bien à la racine du dossier que tu copies
|
| 24 |
COPY --chown=user . /app
|
| 25 |
|
| 26 |
# Expose le port sur lequel ton API FastAPI écoute
|
| 27 |
+
# C'est le port 8010 comme défini dans ton main.py
|
|
|
|
|
|
|
|
|
|
| 28 |
EXPOSE 8010
|
| 29 |
|
| 30 |
# Commande pour lancer l'application avec Uvicorn
|
| 31 |
+
# main:app signifie que l'application FastAPI est dans le fichier 'main.py' et s'appelle 'app'
|
| 32 |
+
# Le port correspond à celui exposé ci-dessus et dans ton main.py
|
| 33 |
CMD ["uvicorn", "main:app", "--host", "0.0.0.0", "--port", "8010"]
|