X-Git-Url: https://gerrit.onap.org/r/gitweb?a=blobdiff_plain;f=rulemgt-standalone%2Fsrc%2Fmain%2Fassembly%2FDockerfile;h=7d02c683186190422d6782f655fa87ca2a9f5175;hb=f939633c87a0ae9e237e6581799d66dd72e3a150;hp=457f4ab819caf6f2dcd2b81b9dd6007d488d09d3;hpb=3df70b98476e280708a52569acb9be4d24259678;p=holmes%2Frule-management.git diff --git a/rulemgt-standalone/src/main/assembly/Dockerfile b/rulemgt-standalone/src/main/assembly/Dockerfile index 457f4ab..7d02c68 100644 --- a/rulemgt-standalone/src/main/assembly/Dockerfile +++ b/rulemgt-standalone/src/main/assembly/Dockerfile @@ -1,31 +1,57 @@ -FROM ubuntu:16.04 +FROM openresty/openresty:alpine MAINTAINER "Guangrong Fu" -EXPOSE 9101 +EXPOSE 9101 9104 9201 -#install openjdk-1.8 -#RUN sed -i 's#http://archive.ubuntu.com#http://mirrors.163.com#g' /etc/apt/sources.list -RUN apt-get update -RUN apt-get install -y openjdk-8-jdk +ENV HOSTNAME=holmes-rule-mgmt \ + LANG=C.UTF-8 \ + JAVA_HOME=/usr/lib/jvm/java-1.8-openjdk \ + PATH=$PATH:/usr/lib/jvm/java-1.8-openjdk/jre/bin:/usr/lib/jvm/java-1.8-openjdk/bin \ + JAVA_ALPINE_VERSION=8.242.08-r0 \ + PG_VERSION=12.2-r0 -#configure the JDK -RUN sed -i 's|#networkaddress.cache.ttl=-1|networkaddress.cache.ttl=10|' /usr/lib/jvm/java-8-openjdk-amd64/jre/lib/security/java.security -ENV JAVA_HOME /usr/lib/jvm/java-8-openjdk-amd64 -ENV PATH $PATH:/usr/lib/jvm/java-8-openjdk-amd64/jre/bin:/usr/lib/jvm/java-8-openjdk-amd64/bin -ENV CLASSPATH .:${JAVA_HOME}/lib:${JRE_HOME}/lib -ENV JRE_HOME ${JAVA_HOME}/jre - -ENV HOSTNAME holmes-rule-mgmt - -#add holmes related resources to the docker image -RUN mkdir /home/holmes +#add the backend package to the docker image WORKDIR /home/holmes ADD holmes-rulemgt-standalone-*-linux64.tar.gz /home/holmes/ -RUN chmod 755 /home/holmes/bin/*.sh - -#install the postgres client -RUN apt-get install -y postgresql-client-9.5 postgresql-contrib-9.5 -ENTRYPOINT /home/holmes/bin/run.sh +#RUN mkdir /etc/ssl/private +ADD holmes-rulemgt-frontend-*.tar.gz /usr/local/openresty/nginx/html/ +ADD nginx-https.conf /usr/local/openresty/nginx/conf +ADD nginx-http.conf /usr/local/openresty/nginx/conf +ADD holmes-frontend.key /etc/ssl/private +ADD holmes-frontend-selfsigned.crt /etc/ssl/certs +ADD dhparam.pem /etc/ssl/certs + +#install java-1.8-openjdk + +# add a simple script that can auto-detect the appropriate JAVA_HOME value +# based on whether the JDK or only the JRE is installed +RUN { \ + echo '#!/bin/sh'; \ + echo 'set -e'; \ + echo; \ + echo 'dirname "$(dirname "$(readlink -f "$(which javac || which java)")")"'; \ + } > /usr/local/bin/docker-java-home \ + && chmod +x /usr/local/bin/docker-java-home \ + && set -x \ + && apk upgrade \ + && apk update \ + && apk add --no-cache openjdk8="$JAVA_ALPINE_VERSION" \ + && [ "$JAVA_HOME" = "$(docker-java-home)" ] \ + #install neccessary tools + && apk add --no-cache curl \ + && apk add --no-cache postgresql-client="$PG_VERSION" \ + && apk add --no-cache nss \ + #add the frontend pacakge to the docker images + && rm /etc/nginx/conf.d/default.conf \ + && chmod -R 777 /usr/local/openresty/nginx/ \ + #switch the user to holmes + && addgroup -S holmes && adduser -S -G holmes holmes \ + && chmod -R a+rw /home/holmes/ \ + && chmod -R a+rw /var/log/ \ + && chmod 755 /home/holmes/bin/*.sh + +USER holmes +CMD ["sh", "/home/holmes/bin/run.sh"]