-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathDockerfile
41 lines (30 loc) · 1.26 KB
/
Dockerfile
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
# syntax=docker/dockerfile:1
ARG PYTHON_VERSION=3.11.9
FROM public.ecr.aws/amazonlinux/amazonlinux:2023-minimal AS base
# Prevents Python from writing pyc files.
ENV PYTHONDONTWRITEBYTECODE=1
# Keeps Python from buffering stdout and stderr to avoid situations where
# the application crashes without emitting any logs due to buffering.
ENV PYTHONUNBUFFERED=1
WORKDIR /app
# Install python3 and pip
RUN dnf install -y python3.11 python3-pip && \
dnf update -y libxml2 --releasever 2023.6.20250218 && \
dnf clean all
COPY /src/requirements.txt .
# Download dependencies as a separate step to take advantage of Docker's caching.
# Leverage a cache mount to /root/.cache/pip to speed up subsequent builds.
# Leverage a bind mount to requirements.txt to avoid having to copy them into
# into this layer.
RUN --mount=type=cache,target=/root/.cache/pip \
--mount=type=bind,source=/src/requirements.txt,target=requirements.txt \
python3 -m pip install -r requirements.txt
# Copy the source code into the container.
COPY /src/ .
# Create data directory and set permissions for nobody user
RUN mkdir -p /data && \
chown -R nobody:nobody /data
# Switch to the non-privileged user to run the application.
USER nobody
# Run app.py when the container launches
CMD ["python3", "app.py"]