forked from project-koku/koku
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Dockerfile
68 lines (56 loc) · 2.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
FROM centos/python-36-centos7
EXPOSE 8080
ENV NODEJS_VERSION=8 \
NODEJS_SCL=rh-nodejs8 \
NPM_RUN=start \
NODEJS_SCL=rh-nodejs8 \
NPM_CONFIG_PREFIX=$HOME/.npm-global \
PATH=$HOME/.local/bin/:$HOME/node_modules/.bin/:$HOME/.npm-global/bin/:$PATH \
LC_ALL=en_US.UTF-8 \
LANG=en_US.UTF-8 \
PIP_NO_CACHE_DIR=off
ENV SUMMARY="Koku is a cloud cost management application" \
DESCRIPTION="Koku is a cloud cost management application"
LABEL summary="$SUMMARY" \
description="$DESCRIPTION" \
io.k8s.description="$DESCRIPTION" \
io.k8s.display-name="Koku" \
io.openshift.expose-services="8080:http" \
io.openshift.tags="python,python36,rh-python36" \
com.redhat.component="python36-docker" \
name="koku" \
version="1" \
maintainer="Red Hat Subscription Management Services"
USER root
# replace nodejs 6 with nodejs 8
RUN INSTALL_PKGS="${NODEJS_SCL} \
${NODEJS_SCL}-npm \
${NODEJS_SCL}-nodejs-nodemon \
" && \
yum-config-manager --enable centos-sclo-rh-testing && \
yum -y --setopt=tsflags=nodocs install --enablerepo=centosplus $INSTALL_PKGS && \
rpm -V $INSTALL_PKGS && \
yum remove -y rh-nodejs6\* && \
ln -s /usr/lib/node_modules/nodemon/bin/nodemon.js /usr/bin/nodemon && \
yum -y clean all --enablerepo='*'
# Copy the S2I scripts from the specific language image to $STI_SCRIPTS_PATH.
COPY openshift/s2i/bin $STI_SCRIPTS_PATH
# Copy extra files to the image.
COPY openshift/root /
# Copy application files to the image.
COPY . ${APP_ROOT}/src
# - Create a Python virtual environment for use by any application to avoid
# potential conflicts with Python packages preinstalled in the main Python
# installation.
# - In order to drop the root user, we have to make some directories world
# writable as OpenShift default security model is to run the container
# under random UID.
RUN source scl_source enable rh-python36 ${NODEJS_SCL} && \
virtualenv ${APP_ROOT} && \
chown -R 1001:0 ${APP_ROOT} && \
fix-permissions ${APP_ROOT} -P && \
rpm-file-permissions && \
$STI_SCRIPTS_PATH/assemble
USER 1001
# Set the default CMD to print the usage of the language image.
CMD $STI_SCRIPTS_PATH/run