-
Notifications
You must be signed in to change notification settings - Fork 60
/
Copy pathDockerfile
107 lines (88 loc) · 3.22 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
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
FROM registry.access.redhat.com/ubi8/ubi-minimal:8.10-1154 AS base
USER root
ENV PYTHON_VERSION=3.9 \
PYTHONUNBUFFERED=1 \
PYTHONIOENCODING=UTF-8 \
LC_ALL=en_US.UTF-8 \
LANG=en_US.UTF-8 \
PIP_NO_CACHE_DIR=off \
PIPENV_VENV_IN_PROJECT=1 \
PIPENV_VERBOSITY=-1 \
APP_ROOT=/opt/rbac \
APP_CONFIG=/opt/rbac/rbac/gunicorn.py \
APP_HOME=/opt/rbac/rbac \
APP_MODULE=rbac.wsgi \
APP_NAMESPACE=rbac \
PLATFORM="el8"
ENV SUMMARY="Insights RBAC is a role based access control web server" \
DESCRIPTION="Insights RBAC is a role based access control web server"
LABEL summary="$SUMMARY" \
description="$DESCRIPTION" \
io.k8s.description="$DESCRIPTION" \
io.k8s.display-name="insights-rbac" \
io.openshift.expose-services="8080:http" \
io.openshift.tags="python,python39,rh-python39" \
com.redhat.component="python39-docker" \
name="insights-rbac" \
version="1" \
maintainer="Red Hat Insights"
# Very minimal set of packages
# glibc-langpack-en is needed to set locale to en_US and disable warning about it
# gcc to compile some python packages (e.g. ciso8601)
# shadow-utils to make useradd available
RUN INSTALL_PKGS="python39 python39-devel glibc-langpack-en libpq-devel gcc shadow-utils" && \
microdnf --nodocs -y upgrade && \
microdnf -y --setopt=tsflags=nodocs --setopt=install_weak_deps=0 install $INSTALL_PKGS && \
rpm -V $INSTALL_PKGS && \
microdnf -y clean all --enablerepo='*'
# PIPENV_DEV is set to true in the docker-compose allowing
# local builds to install the dev dependencies
ARG PIPENV_DEV=False
ARG USER_ID=1001
# Create a Python virtual environment for use by any application to avoid
# potential conflicts with Python packages preinstalled in the main Python
# installation.
RUN python3.9 -m venv /pipenv-venv
ENV PATH="/pipenv-venv/bin:$PATH"
# Install pipenv into the virtual env
RUN \
pip install --upgrade pip && \
pip install pipenv
WORKDIR ${APP_ROOT}
# install dependencies
ENV PIP_DEFAULT_TIMEOUT=100
COPY Pipfile .
COPY Pipfile.lock .
RUN \
# install the dependencies into the working dir (i.e. ${APP_ROOT}/.venv)
pipenv install --deploy && \
# delete the pipenv cache
pipenv --clear
# Runtime env variables:
ENV VIRTUAL_ENV=${APP_ROOT}/.venv
ENV \
# Add the rbac virtual env bin to the front of PATH.
# This activates the virtual env for all subsequent python calls.
PATH="$VIRTUAL_ENV/bin:$PATH" \
PROMETHEUS_MULTIPROC_DIR=/tmp
# copy the src files into the workdir
COPY . .
# create the rbac user
RUN \
adduser rbac -u ${USER_ID} -g 0 && \
chmod ug+rw ${APP_ROOT} ${APP_HOME} ${APP_HOME}/static /tmp
USER rbac
# create the static files
RUN \
python rbac/manage.py collectstatic --noinput && \
# This `app.log` file is created during the `collectstatic` step. We need to
# remove it else the random OCP user will not be able to access it. This file
# will be recreated by the Pod when the application starts.
rm ${APP_HOME}/app.log && \
rm /tmp/counter*
EXPOSE 8080
# GIT_COMMIT is added during build in `build_deploy.sh`
# Set this at the end to leverage build caching
ARG GIT_COMMIT=undefined
ENV GIT_COMMIT=${GIT_COMMIT}
ENTRYPOINT ["./scripts/entrypoint.sh"]