Zookeeper的下载地址:https://github.com/apache/zookeeper/archive/master.zip
zkclient的下载地址:https://github.com/sgroschupf/zkclient
至于Zookeeper的作用和原理我这里就不多赘述了,大家有兴趣可以去查查,这里主要就是动手操作。
搭建集群
首先先看一下本次zk实验服务器的名称和IP情况,这里我们选择了三台服务器作zkserver,因为三台是标配,一台的话就只有leader没有follower,不是很稳定的结构,当然啦如果你的公司土豪的话是可以玩三十台:
dvl-mrszk-001 10.117.0.125dvl-mrszk-002 10.117.1.158
dvl-mrszk-003 10.168.152.227
对这三台服务器都要进行如下的步骤:
1)先把zookeeper.zip传到linux里,然后解压到/usr文件夹下;
2)进入 /usr/zookeeper/conf文件夹,#vim zoo.cfg,在最下面补充上面的三个zkserver,见图:
3)再来到/usr/zookeeper/data文件夹,如果里面有文件就清空所有文件,如果是1号zkserver就# echo 1 > myid,如果当前机器是2号zkserver就# echo 2 > myid,依次类推,这里一定要注意,不可以都写一样。
4)#vim /etc/hosts,还要把这三台机器的ip地址和名字都写进去,如下:
127.0.0.1 localhost
::1 localhost localhost.localdomain localhost6 localhost6.localdomain6
10.117.0.125 dvl-mrszk-001
10.117.1.158 dvl-mrszk-002
10.168.152.227 dvl-mrszk-003
5)再来/usr/zookeeper/bin文件夹,#./zkServer.sh start启动zk,然后再#./zkServer.sh status查看进程情况,如图看见第一台和第三台zkserver的身份是follower,第二台是leader:
至此整个zk集群就搭建并且启动完成了。
注意:zookeeper集群时,zookeeper要求半数以上的机器可用,zookeeper才能提供服务。
如果这里有启动失败的情况,比如'Error contacting service. It is probably not running.'这样的字样,那么有三种可能:
1)data文件夹下的myid有数字重复或者是数字漏写的情况;
2)zoo.cfg里的指定日志文件夹没有手动创建;
3)/etc/hosts下的名字与zoo.cfg里的server字段不相符,注意一下,/etc/hosts里的127.0.0.1的名字不要与本ip后面的名字一模一样,不然zk也无法识别!
4)/etc/hosts名字使用了中文,java系对中文是很不友好的。
验证成果
Zookeeper的配置工具叫Zooinspector,下载地址是:
https://issues.apache.org/jira/secure/attachment/12436620/ZooInspector.zip,下载完直接解压缩就可以在windows里使用。
我们实验的这三台服务器只有内网,但是如果要连接zooinspector,还是需要通过外网权限连接的,这里可以配一个iptables转发规则,配iptables的步骤在这里:,照葫芦画瓢即可,但是要注意,zk的端口是2181。
当然,如果不想费事的话,就直接给zkserver 配一个外网IP,直接连接。
成功连接到zooinspector,就会看到这样的内容,这里的lcconfig是手动添加的,右击鼠标,选择add node,然后直接写上lcconfig就行,这个名字是根据实际需要填写的: