Fork me on GitHub
ZooKeeper安装与运行

ZooKeeper安装与运行

首先从官网下载ZooKeeper压缩包,然后解压下载得到的ZooKeeper压缩包,发现有“bin,conf,lib”等目录。“bin目录”中存放有运行脚本;“conf目录”中存放有配置文件;“lib目录”中存放有运行所需要第三方库。

一、standalone模式

1.1、编辑配置文件

在“conf”目录下,新建一个名为“zoo.cfg”的文件,其中内容如下:

tickTime=2000
dataDir=/home/dsl/tmp/zookeeper
clientPort=2181
  • 1
  • 2
  • 3
  • 1
  • 2
  • 3

1.2、运行ZooKeeper Server

执行bin/zkServer.sh start命令,运行ZooKeeper Server进程,得到如图1所示结果,表示后台运行ZooKeeper Server进程成功。

图1 
这里写图片描述

也可以执行bin/zkServer.sh start-foreground命令,非后台运行ZooKeeper Server进程,得到如图2所示结果。

图2 
这里写图片描述

1.3、运行ZooKeeper命令行客户端

执行bin/zkCli.sh -server 127.0.0.1:2181命令,运行ZooKeeper命令行客户端,得到如图3所示界面,可以在其中调用操作Znode节点树的API。

图3 
这里写图片描述

1.4、调用操作Znode节点树的API

进入“1.3、运行ZooKeeper命令行客户端”中得到的界面,调用操作Znode节点树的API。 
1、获取初始Znode节点 
初始时,存在路径标识为“/zookeeper”的Znode节点,该Znode节点保存一些元数据,不能被删除。 
执行ls /命令,可得到如图4所示结果。

图4 
这里写图片描述

2、创建Znode节点 
执行create /data "data"命令,创建一个Znode节点,路径标识为“/data”,包含内容“data”。再执行ls /命令,得到如图5所示结果。

图5 
这里写图片描述

3、删除Znode节点 
执行delete /data命令,删除路径标识为“/data”的Znode节点。再执行ls /命令,得到如图6所示结果。

图6 
这里写图片描述

二、quorum模式

使用quorum模式有两种形式:1)使用多台机器,在每台机器上运行一个ZooKeeper Server进程;2)使用一台机器,在该台机器上运行多个ZooKeeper Server进程。在生产环境中,一般使用第一种形式,在练习环境中,一般使用第二种形式。

2.1、参数配置

quorum模式下,要使一个ZooKeeper Server进程能够正常运行,需要配置一些参数,以下是常见的一些参数。 
1、data目录 
用于存放进程运行数据。 
2、data目录下的myid文件 
用于存储一个数值,该数值用来作为该ZooKeeper Server进程的标识。 
3、监听Client端请求的端口号 
该端口号用来监听Client端请求。(关于“Client”见《ZooKeeper》 Chapter 2 Getting to Grips with ZooKeeper的图2) 
4、监听同ZooKeeper集群内其他ZooKeeper Server进程通信请求的端口号 
该端口号用来监听同ZooKeeper集群内其他ZooKeeper Server进程的通信请求。 
5、监听ZooKeeper集群内“leader”选举请求的端口号 
该端口号用来监听ZooKeeper集群内“leader”选举的请求。注意这个是ZooKeeper集群内“leader”的选举,跟分布式应用程序无关。

参数配置注意事项: 
1)同一个ZooKeeper集群内,不同ZooKeeper Server进程的标识需要不一样,即myid文件内的值需要不一样 
2)采用上述第2种形式构建ZooKeeper集群,需要注意“目录,端口号”等资源的不可共享性,如果共享会导致ZooKeeper Server进程不能正常运行,比如“data目录,几个监听端口号”都不能被共享

2.2、举例

采用上述第2种形式构建一个使用quorum模式的ZooKeeper集群,集群规划如表1所示。

表1

ZooKeeper Server进程标识(myid文件内数值)data目录监听Client端请求的端口号监听同ZooKeeper集群内其他ZooKeeper Server进程通信请求的端口号监听ZooKeeper集群内“leader”选举请求的端口号配置文件名称
1 /home/dsl/bigdisk/apps/zookeeper-3.4.8/deploy/z1/data 2181 2222 2223 z1.cfg
2 /home/dsl/bigdisk/apps/zookeeper-3.4.8/deploy/z2/data 2182 3333 3334 z2.cfg
3 /home/dsl/bigdisk/apps/zookeeper-3.4.8/deploy/z3/data 2183 4444 4445 z3.cfg

相应的目录结构如图1所示。

图1 
这里写图片描述

“z1.cfg,z2.cfg,z3.cfg”这3个文件的文件内容分别如下所示。

# z1.cfg
tickTime=2000
initLimit=10
syncLimit=5

dataDir=/home/dsl/bigdisk/apps/zookeeper-3.4.8/deploy/z1/data
clientPort=2181
# server.x中的“x”表示ZooKeeper Server进程的标识
# 同一个ZooKeeper集群内的ZooKeeper Server进程间的通信不仅可以使用具体的点IP地址,也可以使用组播地址
server.1=127.0.0.1:2222:2223
server.2=127.0.0.1:3333:3334
server.3=127.0.0.1:4444:4445
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
# z2.cfg
tickTime=2000
initLimit=10
syncLimit=5

dataDir=/home/dsl/bigdisk/apps/zookeeper-3.4.8/deploy/z2/data
clientPort=2182
# server.x中的“x”表示ZooKeeper Server进程的标识
# 同一个ZooKeeper集群内的ZooKeeper Server进程间的通信不仅可以使用具体的点IP地址,也可以使用组播地址
server.1=127.0.0.1:2222:2223
server.2=127.0.0.1:3333:3334
server.3=127.0.0.1:4444:4445
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
# z3.cfg
tickTime=2000
initLimit=10
syncLimit=5

dataDir=/home/dsl/bigdisk/apps/zookeeper-3.4.8/deploy/z3/data
clientPort=2183
# server.x中的“x”表示ZooKeeper Server进程的标识
# 同一个ZooKeeper集群内的ZooKeeper Server进程间的通信不仅可以使用具体的点IP地址,也可以使用组播地址
server.1=127.0.0.1:2222:2223
server.2=127.0.0.1:3333:3334
server.3=127.0.0.1:4444:4445
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12

2.2.1、运行ZooKeeper Server

分别执行bin/zkServer.sh start deploy/z1/z1.cfgbin/zkServer.sh start deploy/z2/z2.cfgbin/zkServer.sh start deploy/z3/z3.cfg命令,运行上述配置的3个ZooKeeper Server进程。

2.2.2、运行ZooKeeper命令行客户端

执行bin/zkCli.sh -server 127.0.0.1:2181,127.0.0.1:2182,127.0.0.1:2183命令,建立ZooKeeper Client端到ZooKeeper集群的连接会话。

2.2.3、调用操作Znode节点树的API

跟“1.4、调用操作Znode节点树的API”一样,可以在“2.2.2、运行ZooKeeper命令行客户端”中得到的界面内,调用操作Znode节点树的API。



备注: 
根据《ZooKeeper》 Chapter 2 Getting to Grips with ZooKeeper可知,“ZooKeeper命令行客户端”本质上还是使用了Java版驱动程序库提供的API或者C版驱动程序库提供的API。 


参考文献: 
[1]https://zookeeper.apache.org/doc/r3.4.8/zookeeperStarted.html 
[2]http://blog.csdn.net/dslztx/article/details/51077606

posted on 2016-05-04 14:22  HackerVirus  阅读(312)  评论(0编辑  收藏  举报