46 lines
1.1 KiB
Docker
46 lines
1.1 KiB
Docker
# The builder image, used to build the virtual environment
|
|
FROM python:3.11-buster as builder
|
|
|
|
RUN apt-get update && \
|
|
apt-get install -y libkrb5-dev libsasl2-dev libldap2-dev libssl-dev && \
|
|
rm -rf /var/lib/apt/lists/*
|
|
|
|
RUN pip install poetry==1.5.1
|
|
|
|
ENV POETRY_NO_INTERACTION=1 \
|
|
POETRY_VIRTUALENVS_IN_PROJECT=1 \
|
|
POETRY_VIRTUALENVS_CREATE=1 \
|
|
POETRY_CACHE_DIR=/tmp/poetry_cache
|
|
|
|
WORKDIR /venv
|
|
|
|
COPY pyproject.toml ./
|
|
COPY poetry.lock ./
|
|
RUN touch README.md
|
|
|
|
RUN poetry install --no-root && \
|
|
rm -rf $POETRY_CACHE_DIR
|
|
|
|
# The runtime image, used to just run the code provided its virtual environment
|
|
FROM python:3.11-slim-buster as runtime
|
|
RUN apt-get update && \
|
|
apt-get install -y libldap2-dev krb5-user libxml2 --no-install-recommends && \
|
|
rm -rf /var/lib/apt/lists/*
|
|
|
|
COPY krb5.conf /etc/krb5.conf
|
|
|
|
RUN useradd -rm app
|
|
USER app
|
|
|
|
ENV VIRTUAL_ENV=/venv/.venv \
|
|
PATH="/venv/.venv/bin:$PATH"
|
|
|
|
COPY --from=builder ${VIRTUAL_ENV} ${VIRTUAL_ENV}
|
|
|
|
WORKDIR /app
|
|
|
|
COPY . .
|
|
|
|
STOPSIGNAL SIGINT
|
|
|
|
CMD ["uwsgi", "--socket=0.0.0.0:8000", "--protocol=http", "--manage-script-name", "--force-cwd=/app", "--mount", "/=webapp:app"]
|