系统环境:
centos:6.5
zookeeper:3.4.6
zookeeper的安装很简单,只要解压然后配置一下文件就可以了。因为zookeeper一般是做成集群模式的,而且节点的数量要是单数比较好,所以最少会有3个节点,具体为什么是单数,要参考zookeeper的选举算法了
节点:192.168.10.160
下载:
cd /opt/tmp
wget http://archive.apache.org/dist/zookeeper/zookeeper-3.4.6/zookeeper-3.4.6.tar.gz
解压文件:
tar -zvxf zookeeper.tar.gz -C /opt/
mv zookeeper-3.4.6 zookeeper346
配置文件修改:
cd /opt/zookeeper346/conf/
mv zoo_sample.cfg zoo.cfg
vim zoo.cfg
修改数据存储目录:
dataDir=/opt/zookeeper346/data/
添加集群节点配置:
server.1=192.168.10.160:2888:3888
server.2=192.168.10.161:2888:3888
server.3=192.168.10.162:2888:3888
创建zookeeper的数据存储目录:
mkdir /opt/zookeeper346
创建节点id信息:
touch /opt/zookeeper346/data/myid
vim myid
myid文件中的内容只会有一个 数字 1
然后用同样的方式在161和162上部署,不过在修改myid文件的时候,161对应2,162对应3,这个对应关系要和zoo.cfg中配置的一样
在160,161,162上部署节点完成以后,首先要关闭防火墙,或者在配置文件中打开2888和3888端口也可以
service iptables stop
然后就可以同时启动了
启动命令:
/opt/zookeeper346/bin
./zkServer.sh start
在160,161,162三台机器上都启动以后, 查看三台机器的leader和follower关系:
160:
161:
162:
可以看出来,zookeeper会自动选举162为leader
这个时候,我们再把leader节点给停了,然后再看一下从属关系
在162节点上停止zookeeper
./zkServer.sh stop
160:
161:
然后会发现,本来是leader的162节点被关闭以后,就是161节点变成leader了
扩展:
常用配置及说明
zookeeper的默认配置文件为zookeeper/conf/zoo_sample.cfg,需要将其修改为zoo.cfg。其中各配置项的含义,解释如下:
1.tickTime:CS通信心跳时间
Zookeeper 服务器之间或客户端与服务器之间维持心跳的时间间隔,也就是每个 tickTime 时间就会发送一个心跳。tickTime以毫秒为单位。
tickTime=2000
2.initLimit:LF初始通信时限
集群中的follower服务器(F)与leader服务器(L)之间初始连接时能容忍的最多心跳数(tickTime的数量)。
initLimit=5
3.syncLimit:LF同步通信时限
集群中的follower服务器与leader服务器之间请求和应答之间能容忍的最多心跳数(tickTime的数量)。
syncLimit=2
4.dataDir:数据文件目录
Zookeeper保存数据的目录,默认情况下,Zookeeper将写数据的日志文件也保存在这个目录里。
dataDir=/opt/zookeeper346/data
5.clientPort:客户端连接端口
客户端连接 Zookeeper 服务器的端口,Zookeeper 会监听这个端口,接受客户端的访问请求。
clientPort=2181
6.服务器名称与地址:集群信息(服务器编号,服务器地址,LF通信端口,选举端口)
这个配置项的书写格式比较特殊,规则如下:
server.N=YYY:A:B
server.1=itcast05:2888:3888
server.2=itcast06:2888:3888
server.3=itcast07:2888:3888