105 lines
2.7 KiB
Docker
105 lines
2.7 KiB
Docker
###############################################
|
|
# Base Image - Python
|
|
###############################################
|
|
FROM python:3.10-slim AS python-base
|
|
|
|
ENV FUWARE_HOME="/app"
|
|
|
|
ENV PYTHONUNBUFFERED=1 \
|
|
PYTHONDONTWRITEBYTECODE=1 \
|
|
PIP_NO_CACHE_DIR=off \
|
|
PIP_DISABLE_PIP_VERSION_CHECK=on \
|
|
PIP_DEFAULT_TIMEOUT=100 \
|
|
POETRY_HOME="/opt/poetry" \
|
|
POETRY_VIRTUALENVS_IN_PROJECT=true \
|
|
POETRY_NO_INTERACTION=1 \
|
|
PYSETUP_PATH="/opt/pysetup" \
|
|
VENV_PATH="/opt/pysetup/.venv"
|
|
|
|
# prepend poetry and venv to path
|
|
ENV PATH="$POETRY_HOME/bin:$VENV_PATH/bin:$PATH"
|
|
|
|
# create user account
|
|
RUN useradd -u 911 -U -d $FUWARE_HOME -s /bin/bash abc \
|
|
&& usermod -G users abc \
|
|
&& mkdir $FUWARE_HOME
|
|
|
|
###############################################
|
|
# Builder Image
|
|
###############################################
|
|
FROM python-base AS builder-base
|
|
RUN apt-get update \
|
|
&& apt-get install --no-install-recommends -y \
|
|
curl \
|
|
build-essential \
|
|
libpq-dev \
|
|
libwebp-dev \
|
|
# LDAP Dependencies
|
|
libsasl2-dev libldap2-dev libssl-dev \
|
|
gnupg gnupg2 gnupg1 \
|
|
&& rm -rf /var/lib/apt/lists/* \
|
|
&& pip install -U --no-cache-dir pip
|
|
|
|
# install poetry - respects $POETRY_VERSION & $POETRY_HOME
|
|
ENV POETRY_VERSION=1.3.1
|
|
RUN curl -sSL https://install.python-poetry.org | python3 -
|
|
|
|
# copy project requirement files here to ensure they will be cached.
|
|
WORKDIR $PYSETUP_PATH
|
|
COPY ./poetry.lock ./pyproject.toml ./
|
|
|
|
# install runtime deps - uses $POETRY_VIRTUALENVS_IN_PROJECT internally
|
|
RUN poetry install --only main
|
|
|
|
###############################################
|
|
# Production Image
|
|
###############################################
|
|
FROM python-base AS production
|
|
ENV PRODUCTION=true
|
|
ENV TESTING=false
|
|
|
|
ARG COMMIT
|
|
ENV GIT_COMMIT_HASH=$COMMIT
|
|
|
|
RUN apt-get update \
|
|
&& apt-get install --no-install-recommends -y \
|
|
gosu \
|
|
iproute2 \
|
|
libldap-common \
|
|
libldap-2.5 \
|
|
&& rm -rf /var/lib/apt/lists/*
|
|
|
|
# create directory used for Docker Secrets
|
|
RUN mkdir -p /run/secrets
|
|
|
|
# copying poetry and venv into image
|
|
COPY --from=builder-base $POETRY_HOME $POETRY_HOME
|
|
COPY --from=builder-base $PYSETUP_PATH $PYSETUP_PATH
|
|
|
|
# copy backend
|
|
COPY ./backend $FUWARE_HOME/backend
|
|
COPY ./poetry.lock ./pyproject.toml $FUWARE_HOME/
|
|
|
|
# Alembic
|
|
COPY ./alembic $FUWARE_HOME/alembic
|
|
COPY ./alembic.ini $FUWARE_HOME/
|
|
|
|
# venv already has runtime deps installed we get a quicker install
|
|
WORKDIR $FUWARE_HOME
|
|
RUN . $VENV_PATH/bin/activate && poetry install --only main
|
|
WORKDIR /
|
|
|
|
VOLUME [ "$FUWARE_HOME/data/" ]
|
|
ENV APP_PORT=9000
|
|
|
|
EXPOSE ${APP_PORT}
|
|
|
|
# ----------------------------------
|
|
ENV HOST 0.0.0.0
|
|
|
|
EXPOSE ${APP_PORT}
|
|
COPY ./docker/entry.sh $FUWARE_HOME/run.sh
|
|
|
|
RUN chmod +x $FUWARE_HOME/run.sh
|
|
ENTRYPOINT ["/app/run.sh"]
|