Linux下单机实现Zookeeper集群
程序员文章站
2022-03-11 07:53:09
安装配置JAVA开发环境 下载ZOOKEEPER zookeeper下载地址 在下载的zookeeper目录里创建3个文件,zk1,zk2,zk3,用于存放每个集群的数据文件。 并在三个目录下创建data和logs目录 配置配置文件 将conf目录下的zoo-sample.cfg 更改为zoo1.c ......
安装配置java开发环境
下载zookeeper
在下载的zookeeper目录里创建3个文件,zk1,zk2,zk3,用于存放每个集群的数据文件。
并在三个目录下创建data和logs目录
配置配置文件
将conf目录下的zoo-sample.cfg 更改为zoo1.cfg , zoo2.cfg ,zoo3.cfg
配置如下
# the number of milliseconds of each tick # 心跳检测时间 ticktime=2000 # the number of ticks that the initial # synchronization phase can take # 心跳检测失败最大次数 initlimit=10 # the number of ticks that can pass between # sending a request and getting an acknowledgement synclimit=5 # the directory where the snapshot is stored. # do not use /tmp for storage, /tmp here is just # example sakes. # 内存数据库保存的模糊快照的目录,如果某个服务器为集群中的一台,则id文件也保存在该目录下 # 快照异步写入,不会阻塞 datadir= ../zk1/data datalogdir= ../zk1/logs # the port at which the clients will connect # tcp监听端口 clientport=2181 # the maximum number of client connections. # increase this if you need to handle more clients #maxclientcnxns=60 # # be sure to read the maintenance section of the # administrator guide before turning on autopurge. # # http://zookeeper.apache.org/doc/current/zookeeperadmin.html#sc_maintenance # # the number of snapshots to retain in datadir #autopurge.snapretaincount=3 # purge task interval in hours # set to "0" to disable auto purge feature #autopurge.purgeinterval=1 # server.myid=ip:port1;port2 #port1:服务器与集群中的leader服务器交换信息的端口 #port2:万一集群中的leader挂了,需要一个端口来重新进行宣讲 选出新的leader server.1=127.0.0.1:2881:3881 server.2=127.0.0.1:2882:3882 server.3=127.0.0.1:2883:3883
三个文件的区别是这三个配置
zoo1.cfg
datadir= ../zk1/data datalogdir= ../zk1/logs clientport=2181
zoo2.cfg
datadir= ../zk2/data datalogdir= ../zk2/logs clientport=2182
zoo3.cfg
datadir= ../zk3/data datalogdir= ../zk3/logs clientport=2183
- ticktime: 基本事件单元,以毫秒为单位。这个时间是作为zookeeper服务器之间或客户端与服务器间维持心跳的时间。也就是每隔ticktime时间就会发送一个心跳
- datadir: 存储内存中数据库快照的位置,就是zookeeper保存数据的目录,默认情况下,zookeeper将数据的日志问也保存在这个目录里
- clientport: 客户端连接zookeeper服务器的端口,默认是2181,zookeeper会监听这个端口,接收客户端的访问请求
- initlimit: 这个配置项是用来配置zookeeper接收客户端初始化连接能忍受多少个心跳时间间隔数。当已经超过10个心跳的时间(ticktime)长度后,zookeeper服务器还没有接收到客户端的返回信息,那么表明这个客户端连接失败。总的时间长度就是 10*2000 = 20 秒
- synclimit: 这个配置项标识leader和follower之间发送消息,请求和应答的长度,最长不能超过多少个ticktime的时间长度,总的时间长度就是 5 * 2000 = 10秒
- server.myid=ip:port1:port2, myid是服务器的编号,一个正整数,一般是0、1、2、3等待,port1表示的是服务器与集群中的leader服务器交换信息的端口,port2表示的是万一集群中的leader服务器宕机了,需要一个端口来重新进行宣讲,选出一个新的leader,如果是不同的机器,可以选用相同的端口,由于本次测试是在单机上进行,因此选用不同的端口。
创建myid文件
在每个目录下的data目录里创建 myid文件,文件内容分别为1,2,3.
启动服务
lgj@lgj-lenovo-g470:~/java/zookeeper-3.4.13/bin$ ./zkserver.sh start ../conf/zoo1.cfg zookeeper jmx enabled by default using config: ../conf/zoo1.cfg starting zookeeper ... started lgj@lgj-lenovo-g470:~/java/zookeeper-3.4.13/bin$ ./zkserver.sh start ../conf/zoo2.cfg zookeeper jmx enabled by default using config: ../conf/zoo2.cfg starting zookeeper ... started lgj@lgj-lenovo-g470:~/java/zookeeper-3.4.13/bin$ ./zkserver.sh start ../conf/zoo3.cfg zookeeper jmx enabled by default using config: ../conf/zoo3.cfg starting zookeeper ... started
查看服务状态
lgj@lgj-lenovo-g470:~/java/zookeeper-3.4.13/bin$ ./zkserver.sh status ../conf/zoo1.cfg zookeeper jmx enabled by default using config: ../conf/zoo1.cfg mode: follower
lgj@lgj-lenovo-g470:~/java/zookeeper-3.4.13/bin$ ./zkserver.sh status ../conf/zoo2.cfg zookeeper jmx enabled by default using config: ../conf/zoo2.cfg mode: leader
lgj@lgj-lenovo-g470:~/java/zookeeper-3.4.13/bin$ ./zkserver.sh status ../conf/zoo3.cfg zookeeper jmx enabled by default using config: ../conf/zoo3.cfg mode: follower
可以看到,zk2选举成为了leader,另外两个为follower。
客户端连接测试
lgj@lgj-lenovo-g470:~/java/zookeeper-3.4.13/bin$ ./zkcli.sh -server 127.0.0.1:2181
lgj@lgj-lenovo-g470:~/java/zookeeper-3.4.13/bin$ ./zkcli.sh -server 127.0.0.1:2182
lgj@lgj-lenovo-g470:~/java/zookeeper-3.4.13/bin$ ./zkcli.sh -server 127.0.0.1:2183
分别连接三个集群节点
在任何一个集群节点进行操作,其他集群也会同步更新。
在zk2创建节点
[zk: 127.0.0.1:2182(connected) 1] create /test1 "" created /test1
在zk1查看节点
[zk: 127.0.0.1:2181(connected) 1] ls / [zookeeper, test1]
leader宕机测试
停止zk2节点工作
lgj@lgj-lenovo-g470:~/java/zookeeper-3.4.13/bin$ ./zkserver.sh stop ../conf/zoo2.cfg zookeeper jmx enabled by default using config: ../conf/zoo2.cfg stopping zookeeper ... stopped
等待超时时间到,重新查看各个节点的状态,可以看到,zk2停止运行之后,在看zk3被集群选举为leader.
lgj@lgj-lenovo-g470:~/java/zookeeper-3.4.13/bin$ ./zkserver.sh status ../conf/zoo1.cfg zookeeper jmx enabled by default using config: ../conf/zoo1.cfg mode: follower lgj@lgj-lenovo-g470:~/java/zookeeper-3.4.13/bin$ ./zkserver.sh status ../conf/zoo2.cfg zookeeper jmx enabled by default using config: ../conf/zoo2.cfg error contacting service. it is probably not running. lgj@lgj-lenovo-g470:~/java/zookeeper-3.4.13/bin$ ./zkserver.sh status ../conf/zoo3.cfg zookeeper jmx enabled by default using config: ../conf/zoo3.cfg mode: leader
上一篇: weUI之分页查询实现