data_api / Dockerfile
QuentinL52's picture
Create Dockerfile
b8fd2da verified
raw
history blame
1.42 kB
# Utilise une image de base Python stable
FROM python:3.9-slim-buster
# Crée un utilisateur non-root pour des raisons de sécurité (bonne pratique de Docker)
RUN useradd -m -u 1000 user
USER user
# Définit le répertoire de travail dans le conteneur
# Tous les fichiers copiés seront relatifs à ce répertoire
WORKDIR /app
# Copie le fichier requirements.txt et installe les dépendances
# Ceci est fait en premier pour tirer parti de la mise en cache de Docker
# Si les dépendances ne changent pas, cette couche ne sera pas reconstruite
COPY --chown=user requirements.txt .
RUN pip install --no-cache-dir --upgrade -r requirements.txt
# Copie le reste de ton code d'application (main.py, etc.)
# Assure-toi que main.py est bien à la racine du dossier que tu copies (. /app)
COPY --chown=user . /app
# Expose le port sur lequel ton API FastAPI écoute
# Hugging Face Spaces s'attend par défaut au port 7860 pour les applications Gradio/Streamlit,
# mais pour une API Docker pure, tu peux définir le port que tu veux.
# Cependant, 7860 est souvent le plus simple car c'est celui que Hugging Face attend implicitement.
# Si ton API écoute sur 8010 comme dans main.py, utilise 8010 ici.
EXPOSE 8010
# Commande pour lancer l'application avec Uvicorn
# app:main signifie que l'application FastAPI est dans le fichier 'main.py' et s'appelle 'app'
CMD ["uvicorn", "main:app", "--host", "0.0.0.0", "--port", "8010"]