diff options
author | GuangrongFu <fu.guangrong@zte.com.cn> | 2018-07-24 15:58:54 +0800 |
---|---|---|
committer | GuangrongFu <fu.guangrong@zte.com.cn> | 2018-07-24 15:58:54 +0800 |
commit | bcb49748e807943be84baece5d5109f75bacc45c (patch) | |
tree | defd8366a95f7b235ee047a12847304d663af8d7 /rulemgt-standalone/src/main/assembly/Dockerfile | |
parent | fcdc765d0f858e5d946d63e818d6cbe39e4de8c5 (diff) |
replace the base image with alpine
Change-Id: I9d81f238d3b0b4821c321a87f0c5512ebc3923e7
Issue-ID: HOLMES-146
Signed-off-by: GuangrongFu <fu.guangrong@zte.com.cn>
Diffstat (limited to 'rulemgt-standalone/src/main/assembly/Dockerfile')
-rw-r--r-- | rulemgt-standalone/src/main/assembly/Dockerfile | 66 |
1 files changed, 34 insertions, 32 deletions
diff --git a/rulemgt-standalone/src/main/assembly/Dockerfile b/rulemgt-standalone/src/main/assembly/Dockerfile index 4714770..03265a6 100644 --- a/rulemgt-standalone/src/main/assembly/Dockerfile +++ b/rulemgt-standalone/src/main/assembly/Dockerfile @@ -1,48 +1,50 @@ -FROM ubuntu:16.04 +FROM openresty/openresty:alpine MAINTAINER "Guangrong Fu" <fu.guangrong@zte.com.cn> 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 -#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 LANG C.UTF-8 -#install neccessary tools -RUN apt-get install -y bash curl vim - -#install nginx -RUN apt-get install -y wget build-essential libtool libpcre3 libpcre3-dev zlib1g-dev openssl -RUN wget http://nginx.org/download/nginx-1.14.0.tar.gz -RUN tar -zxvf nginx-1.14.0.tar.gz -RUN rm nginx-1.14.0.tar.gz -WORKDIR /nginx-1.14.0 -RUN ./configure --prefix=/usr/local/nginx -RUN make install -RUN ln -s /usr/local/nginx/sbin/nginx /usr/bin/nginx -RUN rm -rf /nginx-1.14.0 -ADD holmes-rulemgt-frontend-*.tar.gz /usr/local/nginx/html -ADD holmes.nginx.conf /usr/local/nginx/conf +#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 +ENV JAVA_HOME /usr/lib/jvm/java-1.8-openjdk +ENV PATH $PATH:/usr/lib/jvm/java-1.8-openjdk/jre/bin:/usr/lib/jvm/java-1.8-openjdk/bin -ENV HOSTNAME holmes-rule-mgmt +ENV JAVA_ALPINE_VERSION 8.171.11-r0 + +RUN set -x \ + && apk add --no-cache \ + openjdk8="$JAVA_ALPINE_VERSION" \ + && [ "$JAVA_HOME" = "$(docker-java-home)" ] -#add holmes related resources to the docker image +#install neccessary tools +RUN apk upgrade \ + && apk update \ + && apk add --no-cache curl \ + && apk add --no-cache postgresql-client=10.4-r0 + +#add the frontend pacakge to the docker images +RUN rm /etc/nginx/conf.d/default.conf +ADD holmes-rulemgt-frontend-*.tar.gz /usr/local/openresty/nginx/html +ADD nginx.conf /usr/local/openresty/nginx/conf + +#add the backend package to the docker image RUN mkdir /home/holmes 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 +CMD ["sh", "/home/holmes/bin/run.sh"] |