zookeeper的安装

tar -zxvf  zookeeper-3.4.8.tar.gz

mv zookeeper-3.4.8 /usr/local/

修改zk的配置文件

cp zoo_sample.cfg zoo.cfg

  • tickTime: zookeeper中使用的基本时间单位, 毫秒值.

  • dataDir: 数据目录. 可以是任意目录.

  • dataLogDir: log目录, 同样可以是任意目录. 如果没有设置该参数, 将使用和dataDir相同的设置.

  • clientPort: 监听client连接的端口号

  • initLimit: zookeeper集群中的包含多台server, 其中一台为leader, 集群中其余的server为follower. initLimit参数配置初始化连接时, follower和leader之间的最长心跳时间. 此时该参数设置为5, 说明时间限制为5倍tickTime, 即5*2000=10000ms=10s.

  • syncLimit: 该参数配置leader和follower之间发送消息, 请求和应答的最大时间长度. 此时该参数设置为2, 说明时间限制为2倍tickTime, 即4000ms.

  • server.X=A:B:C 其中X是一个数字, 表示这是第几号server. A是该server所在的IP地址. B配置该server和集群中的leader交换消息所使用的端口. C配置选举leader时所使用的端口. 由于配置的是伪集群模式, 所以各个server的B, C参数必须不同.

tickTime=2000

initLimit=5

syncLimit=2

dataDir=/opt/zookeeper/data

dataLogDir=/opt/zookeeper/log

clientPort=2181

因为我们只有一台测试机,所有server 就按照这个模式去写,注意端口(不同服务器端口可以一样)

server.1=127.0.0.1:2887:3887

server.2=127.0.0.1:2888:3888

server.3=127.0.0.1:2889:3889


完成配置以后,将zookeeper目录拷贝两份v1/v2 修改clientport=2182/2183既可以


创建数据目录

mkdir -p /opt/zookeeper/{data,logs}  目录分别对应3个节点

分别在各自的data目录下touch myid的文件 echo 1/2/3 > myid  数字就是对应每个节点的server.X


最后启动3个节点

./zkServer.sh start

./zkServer.sh status来查看哪一个是leader 那些是follower 一般最先启动的是leader