summaryrefslogtreecommitdiffstats
path: root/rulemgt-standalone/src/main/assembly/Dockerfile
diff options
context:
space:
mode:
authorGuangrongFu <fu.guangrong@zte.com.cn>2018-07-24 15:58:54 +0800
committerGuangrongFu <fu.guangrong@zte.com.cn>2018-07-24 15:58:54 +0800
commitbcb49748e807943be84baece5d5109f75bacc45c (patch)
treedefd8366a95f7b235ee047a12847304d663af8d7 /rulemgt-standalone/src/main/assembly/Dockerfile
parentfcdc765d0f858e5d946d63e818d6cbe39e4de8c5 (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/Dockerfile66
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"]