blob: 6ca395b79e9dee666c2f545e7cca3a6a80ef6577 [file] [log] [blame]
sunil unnava97d04ee2018-11-20 15:29:12 -05001FROM ubuntu:16.04
2
sunil unnavae68d4462018-11-21 21:58:13 -05003ENV ZK_USER=root \
sunil unnava61490fb2018-11-21 19:16:02 -05004 ZK_DATA_DIR=/var/lib/zookeeper/data \
5 ZK_DATA_LOG_DIR=/var/lib/zookeeper/log \
6 ZK_LOG_DIR=/var/log/zookeeper \
7 JAVA_HOME=/usr/lib/jvm/java-8-openjdk-amd64
sunil unnava5e3d91f2018-11-20 14:43:42 -05008
sunil unnava61490fb2018-11-21 19:16:02 -05009ARG GPG_KEY=C823E3E5B12AF29C67F81976F5CECB3CB5E9BD2D
sunil unnava5e3d91f2018-11-20 14:43:42 -050010ARG ZK_DIST=zookeeper-3.4.10
sunil unnava61490fb2018-11-21 19:16:02 -050011
sunil unnava5e3d91f2018-11-20 14:43:42 -050012RUN set -x \
13 && apt-get update \
14 && apt-get install -y openjdk-8-jre-headless wget netcat-openbsd \
sunil unnava97d04ee2018-11-20 15:29:12 -050015 && wget -q "http://www.apache.org/dist/zookeeper/$ZK_DIST/$ZK_DIST.tar.gz" \
sunil unnava5e3d91f2018-11-20 14:43:42 -050016 && wget -q "http://www.apache.org/dist/zookeeper/$ZK_DIST/$ZK_DIST.tar.gz.asc" \
sunil unnava61490fb2018-11-21 19:16:02 -050017 && export GNUPGHOME="$(mktemp -d)" \
18 && gpg --keyserver ha.pool.sks-keyservers.net --recv-key "$GPG_KEY" \
19 && gpg --batch --verify "$ZK_DIST.tar.gz.asc" "$ZK_DIST.tar.gz" \
sunil unnava5e3d91f2018-11-20 14:43:42 -050020 && tar -xzf "$ZK_DIST.tar.gz" -C /opt \
sunil unnava61490fb2018-11-21 19:16:02 -050021 && rm -r "$GNUPGHOME" "$ZK_DIST.tar.gz" "$ZK_DIST.tar.gz.asc" \
sunil unnava5e3d91f2018-11-20 14:43:42 -050022 && ln -s /opt/$ZK_DIST /opt/zookeeper \
23 && rm -rf /opt/zookeeper/CHANGES.txt \
24 /opt/zookeeper/README.txt \
25 /opt/zookeeper/NOTICE.txt \
26 /opt/zookeeper/CHANGES.txt \
27 /opt/zookeeper/README_packaging.txt \
28 /opt/zookeeper/build.xml \
29 /opt/zookeeper/config \
30 /opt/zookeeper/contrib \
31 /opt/zookeeper/dist-maven \
32 /opt/zookeeper/docs \
33 /opt/zookeeper/ivy.xml \
34 /opt/zookeeper/ivysettings.xml \
35 /opt/zookeeper/recipes \
36 /opt/zookeeper/src \
37 /opt/zookeeper/$ZK_DIST.jar.asc \
38 /opt/zookeeper/$ZK_DIST.jar.md5 \
39 /opt/zookeeper/$ZK_DIST.jar.sha1 \
sunil unnava61490fb2018-11-21 19:16:02 -050040 && apt-get autoremove -y wget \
41 && rm -rf /var/lib/apt/lists/*
sunil unnava97d04ee2018-11-20 15:29:12 -050042
sunil unnava61490fb2018-11-21 19:16:02 -050043# Copy configuration generator script to bin
sunil unnava1fd255a2018-11-21 19:40:03 -050044COPY scripts /opt/zookeeper/bin/
sunil unnava94d27692018-11-26 09:37:28 -050045
sunil unnava5e3d91f2018-11-20 14:43:42 -050046
sunil unnava61490fb2018-11-21 19:16:02 -050047# Create a user for the zookeeper process and configure file system ownership
48# for necessary directories and symlink the distribution as a user executable
49RUN set -x \
sunil unnava94d27692018-11-26 09:37:28 -050050 && useradd $ZK_USER \
sunil unnava61490fb2018-11-21 19:16:02 -050051 && [ `id -u $ZK_USER` -eq 1000 ] \
52 && [ `id -g $ZK_USER` -eq 1000 ] \
53 && mkdir -p $ZK_DATA_DIR $ZK_DATA_LOG_DIR $ZK_LOG_DIR /usr/share/zookeeper /tmp/zookeeper /usr/etc/ \
54 && chown -R "$ZK_USER:$ZK_USER" /opt/$ZK_DIST $ZK_DATA_DIR $ZK_LOG_DIR $ZK_DATA_LOG_DIR /tmp/zookeeper \
55 && ln -s /opt/zookeeper/conf/ /usr/etc/zookeeper \
56 && ln -s /opt/zookeeper/bin/* /usr/bin \
57 && ln -s /opt/zookeeper/$ZK_DIST.jar /usr/share/zookeeper/ \
sunil unnavae68d4462018-11-21 21:58:13 -050058&& ln -s /opt/zookeeper/lib/* /usr/share/zookeeper
59
sunil unnava1e6634c2018-11-23 16:40:05 -050060
61RUN chown -R $ZK_USER:$ZK_USER /var/lib/zookeeper/data/myid
62RUN chown -R $ZK_USER:$ZK_USER /opt/zookeeper/bin/start-zookeeper.sh
sunil unnavaa828b812018-11-23 17:02:12 -050063RUN chown -R $ZK_USER:$ZK_USER /opt/zookeeper/bin/zookeeper-metrics.sh
sunil unnava1e6634c2018-11-23 16:40:05 -050064RUN chown -R $ZK_USER:$ZK_USER /opt/zookeeper/bin/zookeeper-ready.sh