ZooKeeper是一个分布式开源框架,提供了协调分布式应用的基本服务,它向外部应用暴露一组通用服务——分布式同步(Distributed Synchronization).命名服务(Naming Service).集群维护(Group Maintenance)等,简化分布式应用协调及其管理的难度,提供高性能的分布式服务。ZooKeeper本身可以以Standalone模式安装运行,不过它的长处在于通过分布式ZooKeeper集群(一个Leader,多个Follower),基于一定的策略来保证ZooKeeper集群的稳定性和可用性,从而实现分布式应用的可靠性。(我是网上抄写的,方便大家学习,请勿吐槽!!)
Dubbo 建议使用 Zookeeper 作为服务的注册中心。
Zookeeper 集群中只要有过半的节点是正常的情况下,那么整个集群对外就是可用的。
正是基于这个 特性,要将 zookeeper集群的节点数量要为奇数(2n+1:如 3、5、7 个节点)
声明:以上都是官网的原话,此教程主要是供大家学习,请各位不要吐槽
根据您自己的业务来决定服务器配置,我这边定义了三台服务器,如下:
服务器 1:xxx.xxx.xxx.xx1 端口:2181、2881、3881
服务器 2:xxx.xxx.xxx.xx2 端口:2182、2882、3882
服务器 3:xxx.xxx.xxx.xx3 端口:2183、2883、3883
1、 修改操作系统的/etc/hosts 文件,添加 IP 与主机名映射:
[root@cloud ~]# vi /etc/hosts
# zookeeper servers
xxx.xxx.xxx.xx1 jeesz-zk-01
xxx.xxx.xxx.xx2 jeesz-zk-02
xxx.xxx.xxx.xx3 jeesz-zk-03
2、 下载或上传 zookeeper-3.4.6.tar.gz 到/home/jeesz/zookeeper 目录:
[root@cloud ~]# cd /home/jeesz/zookeeper
$ wget http://apache.fayea.com/zookeeper/zookeeper-3.4.6/zookeeper-3.4.6.tar.gz
3、 由于我已经下载并上传了文件,故这边直接记录详细的安装过程,解压 zookeeper 安装包,并按节点号对 zookeeper 目录重命名:
[root@cloud zookeeper]# tar -zxvf zookeeper-3.4.6.tar.gz
在xxx.xxx.xxx.xx1服务器:
[root@cloud zookeeper]# mv zookeeper-3.4.6 node-01
在xxx.xxx.xxx.xx2服务器:
[root@cloud zookeeper]# mv zookeeper-3.4.6 node-02
在xxx.xxx.xxx.xx3服务器:
[root@cloud zookeeper]# mv zookeeper-3.4.6 node-03
4、 分别在 zookeeper 节点目录下创建以下目录:
[root@cloud ~]# /home/jeesz/zookeeper/node-0X (X 代表节点号 1、2、3)
[root@cloud node-0X]# mkdir data
[root@cloud node-0X] # mkdir logs
5、 将 zookeeper/node-0X/conf 目录下的 zoo_sample.cfg 文件拷贝一份,命名为 zoo.cfg:
[root@cloud conf] cp zoo_sample.cfg zoo.cfg
6、 修改 zoo.cfg 配置文件:
[root@cloud conf] # vi zoo.cfg
zookeeper/node-01 的配置(/home/jeesz/zookeeper/node-01/conf/zoo.cfg)如下:
dataDir=/home/jeesz/zookeeper/node-01/data
dataLogDir=/home/jeesz/zookeeper/node-01/logs
clientPort=2181
server.1=jeesz-zk-01:2881:3881
server.2=jeesz-zk-02:2882:3882
server.3=jeesz-zk-03:2883:3883
zookeeper/node-02 的配置(/home/jeesz/zookeeper/node-02/conf/zoo.cfg)如下:
dataDir=/home/jeesz/zookeeper/node-02/data
dataLogDir=/home/jeesz/zookeeper/node-02/logs
clientPort=2182
server.1=edu-zk-01:2881:3881
server.2=edu-zk-02:2882:3882
server.3=edu-zk-03:2883:3883
zookeeper/node-03 的配置(/home/jeesz/zookeeper/node-03/conf/zoo.cfg)如下:
dataDir=/home/jeesz/zookeeper/node-03/data
dataLogDir=/home/jeesz/zookeeper/node-03/logs
clientPort=2183
server.1=edu-zk-01:2881:3881
server.2=edu-zk-02:2882:3882
server.3=edu-zk-03:2883:3883
7、 在 dataDir=/home/jeesz/zookeeper/node-0X/data 下创建 myid 文件
编辑 myid 文件,并在对应的 IP 的机器上输入对应的编号。如在 node-01 上,myid 文件内容就是
1,node-02 上就是 2,node-03 上就是 3:
[root@cloud ~]# vi /home/jeesz/zookeeper/node-01/data/myid
1
[root@cloud ~]# vi /home/jeesz/zookeeper/node-02/data/myid
2
[root@cloud ~]# vi /home/jeesz/zookeeper/node-03/data/myid
3
8、 在防火墙中打开要用到的端口 218X、288X、388X
[root@cloud ~]# vi /etc/sysconfig/iptables
如服务器 01 增加以下 3 行:
## zookeeper
-A INPUT -m state --state NEW -m tcp -p tcp --dport 2181 -j ACCEPT
-A INPUT -m state --state NEW -m tcp -p tcp --dport 2881 -j ACCEPT
-A INPUT -m state --state NEW -m tcp -p tcp --dport 3881 -j ACCEPT
重启防火墙:
[root@cloud ~]# service iptables restart
查看防火墙端口状态:
[root@cloud ~]# service iptables status
注意:centos7中使用方法不同,大家可以上网查询一下
9、 启动并测试 zookeeper(要用 jeesz 用户启动,不要用 root):
(1) 到/home/jeesz/zookeeper/node-0X/bin 目录中执行:
[root@cloud ~]# /home/jeesz/zookeeper/node-01/bin/zkServer.sh start
[root@cloud ~]# /home/jeesz/zookeeper/node-02/bin/zkServer.sh start
[root@cloud ~]# /home/jeesz/zookeeper/node-03/bin/zkServer.sh start
(2) 输入 jps 命令查看进程:
[root@cloud ~]# jps
1456 QuorumPeerMain
其中,QuorumPeerMain 是 zookeeper 进程,说明启动正常
(3) 查看状态:
[root@cloud ~]# /home/jeesz/zookeeper/node-01/bin/zkServer.sh status
(4) 查看 zookeeper 服务输出信息:
由于服务信息输出文件在/home/jeesz/zookeeper/node-0X/bin/zookeeper.out
[root@cloud ~]# tail -500f zookeeper.out
10、停止 zookeeper 进程:
[root@cloud ~]# zkServer.sh stop
11、配置 zookeeper 开机使用 jeesz 用户启动:
编辑 node-01、node-02、node-03 中的/etc/rc.local 文件,分别加入:
[root@cloud ~]# vi /etc/rc.local
su - root -c '/home/jeesz/zookeeper/node-01/bin/zkServer.sh start'
su - root -c '/home/jeesz/zookeeper/node-02/bin/zkServer.sh start'
su - root -c '/home/jeesz/zookeeper/node-03/bin/zkServer.sh start'