Zookeeper集群部署

  • A+
所属分类:Linux技术

以前线上所有配置信息全部保存在服务器本地文件中,由于web项目过多,经常重复修改配置,手误导致配置修改错误。为了解决这个问题,通过Zookeeper注册中心,统一维护配置文件,做到一致性。

zookeeper介绍

ZooKeeper是一个分布式的,开放源码的分布式应用程序协调服务,是Google的Chubby一个开源的实现,是Hadoop和HBase的重要组件。它是一个为分布式应用提供一致性服务的软件,提供的功能包括:配置维护、名字服务、分布式同步、组服务等。

zookeeper集群部署

为了保证Zookeeper高可用性,需要部署集群,最少需要三个节点,这里只记录下部署过程,具体参数含义不做介绍。

[

root@linux-node1 conf]# grep '^[a-z]' zoo.cfg
tickTime=2000
initLimit=10
syncLimit=5
dataDir=/zookeeper/data
clientPort=2181
server.1=192.168.56.11:3181:4181
server.2=192.168.56.11:3182:4182
server.3=192.168.56.11:3183:4183

dataDir:数据目录

dataLogDir:日志目录

clientPort:客户端连接端口

tickTime:Zookeeper 服务器之间或客户端与服务器之间维持心跳的时间间隔,也就是每个 tickTime 时间就会发送一个心跳。

initLimit:Zookeeper的Leader 接受客户端(Follower)初始化连接时最长能忍受多少个心跳时间间隔数。当已经超过
5个心跳的时间(也就是tickTime)长度后 Zookeeper 服务器还没有收到客户端的返回信息,那么表明这个客户端连接失败。总的时间长度就是
5*2000=10 秒

syncLimit:表示 Leader 与 Follower 之间发送消息时请求和应答时间长度,最长不能超过多少个tickTime
的时间长度,总的时间长度就是 2*2000=4 秒。

server.A=B:C:D:

A 是一个数字,表示这个是第几号服务器;

B 是这个服务器的 ip 地址;

C 表示的是这个服务器与集群中的 Leader 服务器交换信息的端口;

D 表示的是万一集群中的 Leader 服务器挂了,需要一个端口来重新进行选举,选出一个新的
Leader,而这个端口就是用来执行选举时服务器相互通信的端口。

创建唯一id:

[root@linux-node1 ~]# echo "1" >/zookeeper/data/myid
[root@linux-node2 ~]# echo "2" >/zookeeper/data/myid
[root@linux-node2 ~]# echo "3" >/zookeeper/data/myid

查看集群状态:

[root@linux-node2 ~]#/usr/local/zookeeper/bin/zkServer.sh start
[root@linux-node2 ~]#/usr/local/zookeeper/bin/zkServer.sh status

YaLei

发表评论

:?: :razz: :sad: :evil: :!: :smile: :oops: :grin: :eek: :shock: :???: :cool: :lol: :mad: :twisted: :roll: :wink: :idea: :arrow: :neutral: :cry: :mrgreen: