Zookeeper安装及集群搭建(一)

1.安装单个zookeeper

Linux下安装Zookeeper:https://www.cnblogs.com/zuolun2017/p/8186254.html

2.Zookeeper集群搭建

2.1 下载ZooKeeper的安装包:

http://mirrors.shu.edu.cn/apache/zookeeper/zookeeper-3.4.13/zookeeper-3.4.13.tar.gz

解压复制,重命名到zookeeper-3.4.13-01,zookeeper-3.4.13-02,zookeeper-3.4.13-03目录。

Zookeeper安装及集群搭建(一)_第1张图片

2.2 在每一个conf目录下zookeeper-xxx/conf目录下的zoo-sample.cfg复制一份,文件名修改为zoo.cfg。

每份对应的zookeeper-xxx/都建立data和datalog目录,用于存放日志和数据

各个zoo.cfg文件为

zookeeper-3.4.13-01

tickTime=2000
initLimit=10
syncLimit=5
dataDir=E:\\work\\soft\\zookeeper\\zookeeper-3.4.13-01\\data
dataLogDir=E:\\work\\soft\\zookeeper\\zookeeper-3.4.13-01\\datalog
clientPort=2181
server.1=127.0.0.1:2881:3887
server.2=127.0.0.1:2882:3888
server.3=127.0.0.1:2883:3889

zookeeper-3.4.13-02

tickTime=2000
initLimit=10
syncLimit=5
dataDir=E:\\work\\soft\\zookeeper\\zookeeper-3.4.13-02\\data
dataLogDir=E:\\work\\soft\\zookeeper\\zookeeper-3.4.13-02\\datalog
clientPort=2182
server.1=127.0.0.1:2881:3887
server.2=127.0.0.1:2882:3888
server.3=127.0.0.1:2883:3889

 zookeeper-3.4.13-03

tickTime=2000
initLimit=10
syncLimit=5
dataDir=E:\\work\\soft\\zookeeper\\zookeeper-3.4.13-03\\data
dataLogDir=E:\\work\\soft\\zookeeper\\zookeeper-3.4.13-03\\datalog
clientPort=2183
server.1=127.0.0.1:2881:3887
server.2=127.0.0.1:2882:3888
server.3=127.0.0.1:2883:3889

参数说明:

tickTime=2000

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

initLimit=10

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

syncLimit=5

syncLimit这个配置项标识Leader与Follower之间发送消息,请求和应答时间长度,最长不能超过多少个tickTime的时间长度,总的时间长度就是5*2000=10秒。

dataDir=E:\\work\\soft\\zookeeper\\zookeeper-3.4.13-03\\data

dataDir顾名思义就是Zookeeper保存数据的目录,默认情况下Zookeeper将写数据的日志文件也保存在这个目录里。

clientPort=2181

clientPort这个端口就是客户端(应用程序)连接Zookeeper服务器的端口,Zookeeper会监听这个端口接受客户端的访问请求。

 

server.A=B:C:D

server.1=edu-zk-01:2881:3881

server.2=edu-zk-02:2882:3882

server.3=edu-zk-03:2883:3883

A是一个数字,表示这个是第几号服务器;取值范围: 1~255; 来标识该机器在集群中的机器序号

B是这个服务器的IP地址(或者是与IP地址做了映射的主机名);

C第一个端口用来集群成员的信息交换,表示这个服务器与集群中的Leader服务器交换信息的端口; D是在leader挂掉时专门用来进行选举leader所用的端口。注意:如果是伪集群的配置方式,不同的 Zookeeper 实例通信端口号不能一样,所以要给它们分配不同的端口号。

3、 在dataDir=E:\\work\\soft\\zookeeper\\zookeeper-xxx\\data下创建myid文件

编辑 myid 文件,并在对应的 IP 的机器上输入对应的编号。

如在zookeeper-3.4.13-01 上,myid 文件内容就是1,zookeeper-3.4.13-02上就是2,zookeeper-3.4.13-03上就是3.

 

4、启动zookeeper:

windows下执行

启动: zookeeper-xxx\bin >zkServer.cmd;

查看是否成功运行:bin/zkServer.cmd  status

linux下zookeeper-xxx\bin >zkServer.sh start启动,停止,查询

./zkServer.sh start  #启动
./zkServer.sh stop   #停止
./zkServer.sh status #查询节点状态

启动过程:启动顺序为server1、server2、server3。在启动server1,server2时zk会报错,当所有节点全部启动时错误会消失。

5、测试zookeeper

windows下:

E:\work\soft\zookeeper\zookeeper-3.4.13-02\bin>zkCli.cmd -server 127.0.0.1:2181
Connecting to 127.0.0.1:2181
2018-11-14 11:06:00,779 [myid:] - INFO  [main:Environment@100] - Client environment:zookeeper.version=3.4.13-2d71af4dbe22557fda74f9a9b4309b15a7487f03, built on 06/29/2018 04:05 GMT
2018-11-14 11:06:00,782 [myid:] - INFO  [main:Environment@100] - Client environment:host.name=DESKTOP-OUT8FIE
2018-11-14 11:06:00,783 [myid:] - INFO  [main:Environment@100] - Client environment:java.version=1.8.0_60
2018-11-14 11:06:00,788 [myid:] - INFO  [main:Environment@100] - Client environment:java.vendor=Oracle Corporation
2018-11-14 11:06:00,789 [myid:] - INFO  [main:Environment@100] - Client environment:java.home=E:\Program Files\Java\jdk1.8.0_60\jre
2018-11-14 11:06:00,789 [myid:] - INFO  [main:Environment@100] - Client environment:java.class.path=E:\work\soft\zookeeper\zookeeper-3.4.13-02\bin\..\build\classes;E:\work\soft\zookeeper\zookeeper-3.4.13-02\bin\..\build\lib\*;E:\work\soft\zookeeper\zookeeper-3.4.13-02\bin\..\zookeeper-3.4.13.jar;E:\work\soft\zookeeper\zookeeper-3.4.13-02\bin\..\lib\audience-annotations-0.5.0.jar;E:\work\soft\zookeeper\zookeeper-3.4.13-02\bin\..\lib\jline-0.9.94.jar;E:\work\soft\zookeeper\zookeeper-3.4.13-02\bin\..\lib\log4j-1.2.17.jar;E:\work\soft\zookeeper\zookeeper-3.4.13-02\bin\..\lib\netty-3.10.6.Final.jar;E:\work\soft\zookeeper\zookeeper-3.4.13-02\bin\..\lib\slf4j-api-1.7.25.jar;E:\work\soft\zookeeper\zookeeper-3.4.13-02\bin\..\lib\slf4j-log4j12-1.7.25.jar;E:\work\soft\zookeeper\zookeeper-3.4.13-02\bin\..\conf
2018-11-14 11:06:00,789 [myid:] - INFO  [main:Environment@100] - Client environment:java.library.path=E:\Program Files\Java\jdk1.8.0_60\bin;C:\WINDOWS\Sun\Java\bin;C:\WINDOWS\system32;C:\WINDOWS;C:\ProgramData\Oracle\Java\javapath;C:\WINDOWS\system32;C:\WINDOWS;C:\WINDOWS\System32\Wbem;C:\WINDOWS\System32\WindowsPowerShell\v1.0\;"E:\Program Files\Java\jdk1.8.0_60\bin;E:\Program Files\Java\jdk1.8.0_60\jre\bin;";E:\apache-maven-3.3.9\bin;D:\install\Git\cmd;E:\Program Files\nodejs\;E:\Program Files\nodejs\node_global;E:\tomcat\apache-tomcat-8.5.30;E:\gradle-4.8-bin\gradle-4.8\bin;;C:\WINDOWS\System32\OpenSSH\;D:\install\pycSafefile\x64;C:\Users\7460\AppData\Local\Microsoft\WindowsApps;C:\Users\7460\AppData\Roaming\npm;;.
2018-11-14 11:06:00,789 [myid:] - INFO  [main:Environment@100] - Client environment:java.io.tmpdir=C:\Users\7460\AppData\Local\Temp\
2018-11-14 11:06:00,790 [myid:] - INFO  [main:Environment@100] - Client environment:java.compiler=
2018-11-14 11:06:00,791 [myid:] - INFO  [main:Environment@100] - Client environment:os.name=Windows 10
2018-11-14 11:06:00,792 [myid:] - INFO  [main:Environment@100] - Client environment:os.arch=amd64
2018-11-14 11:06:00,795 [myid:] - INFO  [main:Environment@100] - Client environment:os.version=10.0
2018-11-14 11:06:00,796 [myid:] - INFO  [main:Environment@100] - Client environment:user.name=alen
2018-11-14 11:06:00,796 [myid:] - INFO  [main:Environment@100] - Client environment:user.home=C:\Users\7460
2018-11-14 11:06:00,797 [myid:] - INFO  [main:Environment@100] - Client environment:user.dir=E:\work\soft\zookeeper\zookeeper-3.4.13-02\bin
2018-11-14 11:06:00,799 [myid:] - INFO  [main:ZooKeeper@442] - Initiating client connection, connectString=127.0.0.1:2181 sessionTimeout=30000 watcher=org.apache.zookeeper.ZooKeeperMain$MyWatcher@531d72ca
Welcome to ZooKeeper!

linux下


    [root@localhost bin]# ./zkCli.sh -server 192.168.147.128:2181  

5、几个zNode节点操作的api简单介绍:

    create /parh data      创建一个名为/path的zNode节点,并包含数据data

    delete /path          删除名为/path的zNode节点

    exists /path           检查是否存在名为/path的zNode节点

    setData /path data        设置名为/path的zNode的数据为data

    getData  /path         返回名为/path的zNode节点的数据信息

    getChildren /path      返回所有/path节点的所有子节点列表

  zNode节点还有不同的类型,持久(persistent)节点和临时(ephemeral)节点。持久的zNode,如/path,只能通过调用delete来进行删除,而临时的zNode则与之相反,当创建该节点的客户端崩溃或者关闭了与ZooKeeper服务器的连接时候,这个临时zNode节点就会被删除了。其中临时节点可用于实现分布式锁。

 

参考:

Linux下安装Zookeeper:

https://www.cnblogs.com/zuolun2017/p/8186254.html

https://www.cnblogs.com/wrong5566/p/6056788.html

你可能感兴趣的:(ZooKeeper)