zookeeper集群部署

三台机器作集群

序号 IP 端口
1 10.0.2.101/24 2181 / 2881 /3881
2 10.0.2.102/24 2181 / 2881 / 3881
3 10.0.2.103/24 2181 / 2881 / 3881

配置环境

  1. 配置java环境 (略)
  2. 修改/etc/hosts文件,添加IP与主机名映射
[xiaoshuai.zhu@bigdata1-centos7-shanghai-area0 ~]# sudo vim /etc/hosts
# zookeeper cluster servers
10.211.55.7 bigdata1-centos7-shanghai-area0
10.211.55.8 bigdata2-centos7-shanghai-area0
10.211.55.9 bigdata3-centos7-shanghai-area0

[xiaoshuai.zhu@bigdata1-centos7-shanghai-area0 packages]# wget http://mirror.bit.edu.cn/apache/zookeeper/zookeeper-3.4.9/zookeeper-3.4.9.tar.gz # 下载zookeeper-3.4.9.tar.gz
[xiaoshuai.zhu@bigdata1-centos7-shanghai-area0 packages]# tar -zxvf zookeeper-3.4.9.tar.gz && mv zookeeper-3.4.9 zookeeper # 解压zookeeper安装包,并对节点重命名
[xiaoshuai.zhu@bigdata1-centos7-shanghai-area0 packages]# cd zookeeper && mkdir data && mkdir logs  # 在zookeeper的各个节点下创建数据和日志目录
[xiaoshuai.zhu@bigdata1-centos7-shanghai-area0 zookeeper]# cd conf
[xiaoshuai.zhu@bigdata1-centos7-shanghai-area0 conf]# cp zoo_sample.cfg zoo.cfg 
[xiaoshuai.zhu@bigdata1-centos7-shanghai-area0 conf]# vim zoo.cfg
clientPort=2181
dataDir=/home.xiaoshuai.zhu/zookeeper/data
dataLogDir=/home.xiaoshuai.zhu/zookeeper/logs

server.1=bigdata1-centos7-shanghai-area0:2881:3881
server.2=bigdata2-centos7-shanghai-area0:2881:3881
server.3=bigdata3-centos7-shanghai-area0:2881:3881

参数说明:
tickTime=2000
tickTime这个时间是作为Zookeeper服务器之间或客户端与服务器之间维持心跳的时间间隔,也就是每个tickTime时间就会发送一个心跳。
initLimit=10
initLimit这个配置项是用来配置Zookeeper接受客户端(这里所说的客户端不是用户连接Zookeeper服务器的客户端,而是Zookeeper服务器集群中连接到Leader的Follower 服务器)初始化连接时最长能忍受多少个心跳时间间隔数。当已经超过10个心跳的时间(也就是tickTime)长度后Zookeeper 服务器还没有收到客户端的返回信息,那么表明这个客户端连接失败。总的时间长度就是102000=20 秒。
syncLimit=5
syncLimit这个配置项标识Leader与Follower之间发送消息,请求和应答时间长度,最长不能超过多少个tickTime的时间长度,总的时间长度就是5
2000=10秒。
dataDir=/home.xiaoshuai.zhu/zookeeper/data
dataDir顾名思义就是Zookeeper保存数据的目录,默认情况下Zookeeper将写数据的日志文件也保存在这个目录里。
clientPort=2181
clientPort这个端口就是客户端(应用程序)连接Zookeeper服务器的端口,Zookeeper会监听这个端口接受客户端的访问请求。
server.A=B:C:D
server.1=bigdata1-centos7-shanghai-area0:2881:3881
server.2=bigdata2-centos7-shanghai-area0:2881:3881
server.3=bigdata3-centos7-shanghai-area0:2881:3881
A是一个数字,表示这个是第几号服务器;
B是这个服务器的IP地址(或者是与IP地址做了映射的主机名);
C第一个端口用来集群成员的信息交换,表示这个服务器与集群中的Leader服务器交换信息的端口;
D是在leader挂掉时专门用来进行选举leader所用的端口。
注意:如果是伪集群的配置方式,不同的 Zookeeper 实例通信端口号不能一样,所以要给它们分配不同的端口号。注意:如果是伪集群的配置方式,不同的 Zookeeper 实例通信端口号不能一样,所以要给它们分配不同的端口号。

[xiaoshuai.zhu@bigdata1-centos7-shanghai-area0 zookeeper]# cd /home.xiaoshuai.zhu/zookeeper/data
[xiaoshuai.zhu@bigdata1-centos7-shanghai-area0 data]# touch myid # 编辑myid文件,并在对应的IP的机器上输入对应的编号。如在bigdata1上,myid文件内容就是1
[xiaoshuai.zhu@bigdata1-centos7-shanghai-area0 data]# vi myid  # 值为1
[xiaoshuai.zhu@bigdata1-centos7-shanghai-area0 data]# cd ../bin
[xiaoshuai.zhu@bigdata1-centos7-shanghai-area0 bin]# ./zkServer.sh start # 进入/bin目录下执行,jps命令查看进程,QuorumPeerMain是zookeeper进程,说明启动正常
[xiaoshuai.zhu@bigdata1-centos7-shanghai-area0 bin]# tail -500 f zookeeper.out # 查看zookeeper服务输出信息,服务信息输出文件在/bin/zookeeper.out
上一篇
下一篇