Docker搭建Zookeeper集群
这之前的准备和Docker搭建Hadoop集群是一样的,请关注上一篇笔记。
第一步根据上次wiki中的方法启动docker容器
docker run --rm -it -h zoo1 --name zoo1 ice/hadoop /bin/bashdocker run --rm -it -h zoo2 --name zoo2 ice/hadoop /bin/bashdocker run --rm -it -h zoo3 --name zoo3 ice/hadoop /bin/bash
确认/etc/profile生效的配置
/etc/profile最后添加配置,一定要对应自己的路径export JAVA_HOME=/usr/lib/jvm/java-1.7.0-openjdk.x86_64/export CLASSPATH=.:$JAVA_HOME/lib/dt:$JAVA_HOME/lib/tools.jarexport HADOOP_HOME=/root/hadoop-2.7.1export ZOOKEEPER_HOME=/root/zookeeper-3.4.6/export HBASE_HOME=/root/hbase-1.1.2/export PATH=$JAVA_HOME/bin:$PATH:$HADOOP_HOME/bin:$ZOOKEEPER_HOME/bin:$ZOOKEEPER_HOME/conf:$HBASE_HOME/bin
zoo1:source /etc/profilezoo2:source /etc/profilezoo3:source /etc/profile
修改zookeeper配置文件conf/zoo.cfg
如果没有该文件:cp conf/zoo_sample.cfg conf/zoo.cfgserver.1=zoo1:2888:3888server.2=zoo2:2888:3888server.3=zoo3:2888:3888
确定每个Zookeeper的id
对应zoo序号执行echo 1 > /tmp/zookeeper/myidecho 2 > /tmp/zookeeper/myidecho 3 > /tmp/zookeeper/myid
启动Zookeeper
每个容器都执行zkServer.sh start
验证Zookeeper状态
每个容器都执行zkServer.sh status
这里会有问题,提示有问题JMX enabled by defaultUsing config: /root/zookeeper-3.4.6/bin/../conf/zoo.cfgError contacting service. It is probably not running.不要怕,确认两点即可第一:确认/etc/hosts中是否有各个节点域名解析第二:是否/tmp/zookeeper/myid有重复值