阿里云搭建Zookeeper集群测试

配置参数说明

Zookeeper中的配置文件zoo.cfg中参数含义解读如下:
1.tickTime =2000:通信心跳数,Zookeeper服务器与客户端心跳时间,单位毫秒Zookeeper使用的基本时间,服务器之间或客户端与服务器之间维持心跳的时间间隔,也就是每个tickTime时间就会发送一个心跳,时间单位为毫秒。它用于心跳机制,并且设置最小的session超时时间为两倍心跳时间。(session的最小超时时间是2*tickTime)

2.initLimit =10:LF初始通信时限集群中的Follower跟随者服务器与Leader领导者服务器之间初始连接时能容忍的最多心跳数(tickTime的数量),用它来限定集群中的Zookeeper服务器连接到Leader的时限。

3.syncLimit =5:LF同步通信时限集群中Leader与Follower之间的最大响应时间单位,假如响应超过syncLimit * tickTime,Leader认为Follwer死掉,从服务器列表中删除Follwer。

4.dataDir:数据文件目录+数据持久化路径主要用于保存Zookeeper中的数据。

5.clientPort =2181:客户端连接端口监听客户端连接的端口。

选举机制

  1. 半数机制:集群中半数以上机器存活,集群可用。所以Zookeeper适合安装奇数台服务器。
  2. Zookeeper虽然在配置文件中并没有指定Master和Slave。但是,Zookeeper工作时,是有一个节点为Leader,其他则为Follower,Leader是通过内部的选举机制临时产生的。
  3. 以一个简单的例子来说明整个选举的过程。
    假设有五台服务器组成的Zookeeper集群,它们的id从1-5,同时它们都是最新启动的,也就是没有历史数据,在存放数据量这一点上,都是一样的。假设这些服务器依序启动,来看看会发生什么,如图
    阿里云搭建Zookeeper集群测试_第1张图片
    (1)服务器1启动,此时只有它一台服务器启动了,它发出去的报文没有任何响应,所以它的选举状态一直是LOOKING状态。
    (2)服务器2启动,它与最开始启动的服务器1进行通信,互相交换自己的选举结果,由于两者都没有历史数据,所以id值较大的服务器2胜出,但是由于没有达到超过半数以上的服务器都同意选举它(这个例子中的半数以上是3),所以服务器1、2还是继续保持LOOKING状态。
    (3)服务器3启动,根据前面的理论分析,服务器3成为服务器1、2、3中的老大,而与上面不同的是,此时有三台服务器选举了它,所以它成为了这次选举的Leader。
    (4)服务器4启动,根据前面的分析,理论上服务器4应该是服务器1、2、3、4中最大的,但是由于前面已经有半数以上的服务器选举了服务器3,所以它只能接收当小弟的命了。
    (5)服务器5启动,同4一样当小弟。

集群搭建

集群的规划

阿里云搭建Zookeeper集群测试_第2张图片

新建一个集群的文件夹

阿里云搭建Zookeeper集群测试_第3张图片

准备三个zookeeper

阿里云搭建Zookeeper集群测试_第4张图片

zk1

创建data目录和日志目录log
阿里云搭建Zookeeper集群测试_第5张图片
给数据目录里面新建一个myid文件
阿里云搭建Zookeeper集群测试_第6张图片
给myid里面加入一个值为 1 (同理zk2为2 zk3为3)

修改zk1/conf/zoo.cfg

#隔间时间的单位,以后它是配置时间的一个单位
tickTime=2000
# 10 * 2000 = 时间 初始化超时时间,和集群里面的机器交流,最大的间隔时间,若超过该时间,则认为超时
initLimit=10
# 同步数据的超时时间,小弟从大佬里面复制数据,超时的时间为 5 * 2000 
syncLimit=5
# zookeeper 的数据目录,三个zk 的数据目录需要不同才行
dataDir=/usr/local/zk-cluster/zk1/data
# zookeeper的日志目录
dataLogDir=/usr/local/zk-cluster/zk1/log
# zookeeper 的client的端口号
clientPort=2181
# 集群的配置文件
#第几个服务器(1,2,3来自数据目录的一个myid文件,该文件里面保存着当前集群的标识(1,2,3))
# 后面的ip代表将绑定那个ip地址 第一个端口:代表在集群内部,数据复制的接口 第二个端口代表:选举端口
server.1=192.168.110.121:2888:3888
server.2=192.168.110.121:2889:3889  (服务器的话就改为内网IP)
server.3=192.168.110.121:2887:3887

注意上面配置文件的最后,如果是云服务器就写成内网IP !!!

zk2 zk3

创建data目录和日志目录log
阿里云搭建Zookeeper集群测试_第7张图片
阿里云搭建Zookeeper集群测试_第8张图片
给数据目录里面新建一个myid文件并给值为2
在这里插入图片描述
给数据目录里面新建一个myid文件并给值为3
阿里云搭建Zookeeper集群测试_第9张图片

修改zk2 、zk3 的配置文件,和zk1一样,注意data和log目录有轻微变动;端口zk2:2182,
zk3:2183; 然后就可以进行测试了!(服务器的话要注意把配置最后的IP改为内网IP)

你可能感兴趣的:(框架学习)