diff --git a/zookeeper/3.4.12/Dockerfile b/zookeeper/3.4.12/Dockerfile new file mode 100644 index 0000000..1415317 --- /dev/null +++ b/zookeeper/3.4.12/Dockerfile @@ -0,0 +1,38 @@ +FROM centos:7 + +MAINTAINER Yang + +ENV ZOOKEEPER_VERSION=3.4.12 + +RUN yum install -y wget java-1.8.0-openjdk.x86_64 + +RUN cd / && wget http://mirror.bit.edu.cn/apache/zookeeper/zookeeper-$ZOOKEEPER_VERSION/zookeeper-$ZOOKEEPER_VERSION.tar.gz \ + && tar -zxvf zookeeper-$ZOOKEEPER_VERSION.tar.gz \ + && rm -rf zookeeper-$ZOOKEEPER_VERSION.tar.gz \ + && mv zookeeper-$ZOOKEEPER_VERSION zookeeper + +RUN mkdir /data /dataLogs /logs + +RUN echo "ZONE=Asia/Shanghai" > /etc/sysconfig/clock && \ + rm -rf /etc/localtime && \ + ln -sf /usr/share/zoneinfo/Asia/Shanghai /etc/localtime + +RUN echo "tickTime=2000" >> /zookeeper/conf/zoo.cfg && \ + echo "dataDir=/data" >> /zookeeper/conf/zoo.cfg && \ + echo "dataDir=/dataLogs" >> /zookeeper/conf/zoo.cfg && \ + echo "clientPort=2181" >> /zookeeper/conf/zoo.cfg && \ + echo "initLimit=5" >> /zookeeper/conf/zoo.cfg && \ + echo "syncLimit=2" >> /zookeeper/conf/zoo.cfg + +RUN sed -i 's/ZOO_LOG_DIR="."/ZOO_LOG_DIR="\/logs"/' /zookeeper/bin/zkEnv.sh && \ + sed -i 's/ZOO_LOG4J_PROP="INFO,CONSOLE"/ZOO_LOG4J_PROP="INFO,ROLLINGFILE"/' /zookeeper/bin/zkEnv.sh && \ + sed -i 's/zookeeper.root.logger=INFO, CONSOLE/zookeeper.root.logger=INFO,ROLLINGFILE/' /zookeeper/conf/log4j.properties && \ + sed -i 's/zookeeper.log.dir=./zookeeper.log.dir=\/logs/' /zookeeper/conf/log4j.properties + +COPY start.sh / + +RUN chmod 777 /start.sh + +EXPOSE 2181 2888 3888 + +ENTRYPOINT ["/start.sh"] diff --git a/zookeeper/3.4.12/start.sh b/zookeeper/3.4.12/start.sh new file mode 100644 index 0000000..8fde749 --- /dev/null +++ b/zookeeper/3.4.12/start.sh @@ -0,0 +1,35 @@ +#!/bin/bash + +echo "$ZOO_MY_ID" > /data/myid + +if [ -n "$SERVICE_1" ]; then + echo "service.1=$SERVICE_1:2888:3888" >> /zookeeper/conf/zoo.cfg +fi + +if [ -n "$SERVICE_2" ]; then + echo "service.1=$SERVICE_2:2888:3888" >> /zookeeper/conf/zoo.cfg +fi + +if [ -n "$SERVICE_3" ]; then + echo "service.1=$SERVICE_3:2888:3888" >> /zookeeper/conf/zoo.cfg +fi + +if [ -n "$SERVICE_4" ]; then + echo "service.1=$SERVICE_4:2888:3888" >> /zookeeper/conf/zoo.cfg +fi + +if [ -n "$SERVICE_5" ]; then + echo "service.1=$SERVICE_5:2888:3888" >> /zookeeper/conf/zoo.cfg +fi + +if [ -n "$SERVICE_6" ]; then + echo "service.1=$SERVICE_6:2888:3888" >> /zookeeper/conf/zoo.cfg +fi + +if [ -n "$SERVICE_7" ]; then + echo "service.1=$SERVICE_7:2888:3888" >> /zookeeper/conf/zoo.cfg +fi + + + +/zookeeper/bin/zkServer.sh start-foreground diff --git a/zookeeper/README.md b/zookeeper/README.md new file mode 100644 index 0000000..b4a9b91 --- /dev/null +++ b/zookeeper/README.md @@ -0,0 +1,23 @@ +# zookeeper 集群搭建 +## 创建镜像 +进入相应版本文件夹 +```bash +docker build -t zookeeper:3.4.12 . +``` +## 生成容器 +```bash +docker run -d \ + --privileged=true \ + -p 2181:2181 \ + -p 2888:2888 \ + -p 3888:3888 \ + -v /data/zookeeper/data:/data \ + -v /data/zookeeper/dataLogs:/dataLogs \ + -v /data/zookeeper/logs:/logs \ + -e ZOO_MY_ID=1 \ + -e SERVICE_1=10.211.55.11 \ + -e SERVICE_2=10.211.55.12 \ + -e SERVICE_3=10.211.55.13 \ + --name zookeeper \ + zookeeper:3.4.12 +``` \ No newline at end of file