updated dockerfile
Browse files- Dockerfile +26 -13
Dockerfile
CHANGED
|
@@ -1,29 +1,42 @@
|
|
| 1 |
# Use a lightweight Python image
|
| 2 |
FROM python:3.11-slim
|
| 3 |
|
| 4 |
-
# Install
|
| 5 |
-
RUN apt-get update && apt-get install -y \
|
| 6 |
ffmpeg \
|
| 7 |
git \
|
| 8 |
&& rm -rf /var/lib/apt/lists/*
|
| 9 |
|
| 10 |
-
#
|
| 11 |
-
|
|
|
|
|
|
|
| 12 |
|
| 13 |
-
#
|
| 14 |
-
|
| 15 |
|
| 16 |
-
#
|
| 17 |
-
#
|
| 18 |
-
|
| 19 |
|
| 20 |
-
#
|
| 21 |
-
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
| 22 |
|
| 23 |
# Expose the port the app will run on. Hugging Face Spaces typically use 7860.
|
| 24 |
EXPOSE 7860
|
| 25 |
|
| 26 |
# Start the Flask app using Gunicorn.
|
| 27 |
-
#
|
| 28 |
-
# We bind to 0.0.0.0 and the port specified by the PORT env var, with a fallback to 7860.
|
| 29 |
CMD ["gunicorn", "--worker-class", "gevent", "--timeout", "3600", "--bind", "0.0.0.0:7860", "app:app"]
|
|
|
|
| 1 |
# Use a lightweight Python image
|
| 2 |
FROM python:3.11-slim
|
| 3 |
|
| 4 |
+
# Install system dependencies like ffmpeg and git as the root user
|
| 5 |
+
RUN apt-get update && apt-get install -y --no-install-recommends \
|
| 6 |
ffmpeg \
|
| 7 |
git \
|
| 8 |
&& rm -rf /var/lib/apt/lists/*
|
| 9 |
|
| 10 |
+
# Create a dedicated, non-root user for security.
|
| 11 |
+
# Hugging Face and other platforms run containers as a user like this.
|
| 12 |
+
RUN useradd -m -u 1000 user
|
| 13 |
+
ENV HOME=/home/user
|
| 14 |
|
| 15 |
+
# Set the working directory inside the new user's home directory
|
| 16 |
+
WORKDIR $HOME/app
|
| 17 |
|
| 18 |
+
# Copy the requirements file and set its ownership to the new user.
|
| 19 |
+
# This helps with Docker's layer caching.
|
| 20 |
+
COPY --chown=user:user requirements.txt .
|
| 21 |
|
| 22 |
+
# Switch from the root user to the non-root user
|
| 23 |
+
USER user
|
| 24 |
+
|
| 25 |
+
# Install Python dependencies into the user's home directory
|
| 26 |
+
# This avoids any permission issues with system-wide package installation.
|
| 27 |
+
RUN pip install --no-cache-dir --user -r requirements.txt
|
| 28 |
+
|
| 29 |
+
# Add the user's local bin directory to the system's PATH.
|
| 30 |
+
# This is crucial so that executables installed by pip (like gunicorn) can be found.
|
| 31 |
+
ENV PATH="$HOME/.local/bin:$PATH"
|
| 32 |
+
|
| 33 |
+
# Copy the rest of the project files, ensuring they are also owned by the user.
|
| 34 |
+
# This is what fixes the "Permission denied: 'cookies.txt'" error.
|
| 35 |
+
COPY --chown=user:user . .
|
| 36 |
|
| 37 |
# Expose the port the app will run on. Hugging Face Spaces typically use 7860.
|
| 38 |
EXPOSE 7860
|
| 39 |
|
| 40 |
# Start the Flask app using Gunicorn.
|
| 41 |
+
# Binding to 0.0.0.0 makes it accessible from outside the container.
|
|
|
|
| 42 |
CMD ["gunicorn", "--worker-class", "gevent", "--timeout", "3600", "--bind", "0.0.0.0:7860", "app:app"]
|