forked from kow3ns/kubernetes-zookeeper
-
Notifications
You must be signed in to change notification settings - Fork 1
/
Dockerfile
86 lines (77 loc) · 3.21 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
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
FROM openjdk:11.0.8-jre-slim-buster
ENV ZK_USER=zookeeper \
ZK_DATA_DIR=/var/lib/zookeeper/data \
ZK_DATA_LOG_DIR=/var/lib/zookeeper/log \
ZK_LOG_DIR=/var/log/zookeeper \
ZK_DOWNLOAD_URL=https://archive.apache.org/dist/zookeeper \
APACHE_KEYS="68E327C1 6E1CC7A4 8EE2F25C D2C80E32 820F225C 92BC2F2B ADAFD097 \
B5E9BD2D 767E7473 41CF31A9 173C31A2 15DFA1BA A615D22C 3B5B5147 8F6E35FC"
RUN set -x \
&& apt-get update \
&& apt-get -qq -y --no-install-recommends install \
gnupg \
wget \
socat \
&& rm -rf /var/lib/apt/lists/*
RUN for key in $APACHE_KEYS; do \
gpg --keyserver ha.pool.sks-keyservers.net --recv-key "$key" || \
gpg --keyserver keyserver.ubuntu.com --recv-key "$key"; \
done
ARG ZK_DIST=zookeeper-3.4.14
ARG ZK_PACKAGE=$ZK_DIST
RUN wget -q "$ZK_DOWNLOAD_URL/$ZK_DIST/$ZK_PACKAGE.tar.gz" \
&& wget -q "$ZK_DOWNLOAD_URL/$ZK_DIST/$ZK_PACKAGE.tar.gz.asc" \
&& apt-get autoremove -y wget \
&& gpg --batch --verify "$ZK_PACKAGE.tar.gz.asc" "$ZK_PACKAGE.tar.gz" \
&& tar -xzf "$ZK_PACKAGE.tar.gz" -C /opt \
&& rm -r "$ZK_PACKAGE.tar.gz" "$ZK_PACKAGE.tar.gz.asc" \
&& ln -s /opt/$ZK_PACKAGE /opt/zookeeper \
&& rm -rf /opt/zookeeper/CHANGES.txt \
/opt/zookeeper/README.txt \
/opt/zookeeper/NOTICE.txt \
/opt/zookeeper/CHANGES.txt \
/opt/zookeeper/README_packaging.txt \
/opt/zookeeper/build.xml \
/opt/zookeeper/config \
/opt/zookeeper/contrib \
/opt/zookeeper/dist-maven \
/opt/zookeeper/docs \
/opt/zookeeper/ivy.xml \
/opt/zookeeper/ivysettings.xml \
/opt/zookeeper/recipes \
/opt/zookeeper/src \
/opt/zookeeper/$ZK_PACKAGE.jar.asc \
/opt/zookeeper/$ZK_PACKAGE.jar.md5 \
/opt/zookeeper/$ZK_PACKAGE.jar.sha1
# Datadog agent related environment variables
ENV DD_SERVICE="flink-zk"
ENV DD_TRACE_ENABLED="false"
# Environment variables needed to activate datadog integration
# SERVER_JVMFLAGS="-javaagent:/opt/zookeeper/dd-java-agent.jar"
# DD_ENV
# DD_AGENT_HOST
# datadog java agent arguments
ARG DD_REPO_BASE_URL=https://repository.sonatype.org/service/local/repositories
ARG DD_VERSION=0.56.0
RUN apt-get update \
&& apt-get install --no-install-recommends -y wget=1.20.1-1.1 \
&& wget -O /opt/zookeeper/dd-java-agent.jar \
${DD_REPO_BASE_URL}/central-proxy/content/com/datadoghq/dd-java-agent/${DD_VERSION}/dd-java-agent-${DD_VERSION}.jar \
&& apt-get remove --purge -y wget \
&& rm -rf /var/lib/apt/lists/*
#Copy configuration generator script to bin
COPY scripts /opt/zookeeper/bin/
# Create a user for the zookeeper process and configure file system ownership
# for nessecary directories and symlink the distribution as a user executable
RUN set -x \
&& useradd $ZK_USER \
&& [ `id -u $ZK_USER` -eq 1000 ] \
&& [ `id -g $ZK_USER` -eq 1000 ] \
&& mkdir -p $ZK_DATA_DIR $ZK_DATA_LOG_DIR $ZK_LOG_DIR \
/usr/share/zookeeper /tmp/zookeeper /usr/etc/ \
&& chown -R "$ZK_USER:$ZK_USER" /opt/$ZK_PACKAGE $ZK_DATA_DIR \
$ZK_LOG_DIR $ZK_DATA_LOG_DIR /tmp/zookeeper \
&& ln -s /opt/zookeeper/conf/ /usr/etc/zookeeper \
&& ln -s /opt/zookeeper/bin/* /usr/bin \
&& ln -s /opt/zookeeper/$ZK_PACKAGE.jar /usr/share/zookeeper/ \
&& ln -s /opt/zookeeper/lib/* /usr/share/zookeeper