ZooKeeper的安装和API
Zookeeper的分布式安装和API介绍:
安装教程
在datanode1、datanode2和datanode3三个节点上部署Zookeeper。
步骤
- 解压zookeeper安装包到/opt/module/目录下
1 |
tar -zxvf zookeeper-3.4.10.tar.gz -C /opt/module/ |
- /opt/module/zookeeper-3.4.10/这个目录下创建zkData
1 |
mkdir -p zkData |
- 重命名/opt/module/zookeeper-3.4.10/conf这个目录下的zoo_sample.cfg为zoo.cfg
1 |
mv zoo_sample.cfg zoo.cfg |
- 配置zoo.cfg文件
1 |
######################cluster########################## |
server.A=B:C:D。
A是一个数字,表示这个是第几号服务器;
B是这个服务器的ip地址或者主机名;
C是这个服务器与集群中的Leader服务器交换信息的端口;
D是万一集群中的Leader服务器挂了,需要一个端口来重新进行选举,选出一个新的Leader,而这个端口就是用来执行选举时服务器相互通信的端口。
集群模式下配置一个文件myid,这个文件在dataDir目录下,这个文件里面有一个数据就是A的值,Zookeeper启动时读取此文件,拿到里面的数据与zoo.cfg里面的配置信息比较从而判断到底是哪个server。
- 在/opt/module/zookeeper-3.4.10/zkData目录下创建一个myid的文件
1 |
touch myid |
-
编辑myid文件,各个节点的值根据配置文件zoo.cfg来
-
拷贝配置好的zookeeper到其他机器上并分别修改myid文件中内容为3、4
1 |
touch myid |
- 启动脚本
1 |
!/bin/sh |
停止脚本换成stop即可
- 查看zhua状态
1 |
zkServer.sh status |
客户端命令行操作
命令基本语法 | 功能描述 |
---|---|
help | 显示所有操作命令 |
ls path [watch] | 使用 ls 命令来查看当前znode中所包含的内容 |
ls2 path [watch] | 查看当前节点数据并能看到更新次数等数据 |
create | 普通创建 -s 含有序列 -e 临时(重启或者超时消失) |
get path [watch] | 获得节点的值 |
set | 设置节点的具体值 |
stat | 查看节点状态 |
delete | 删除节点 |
rmr | 递归删除节点 |
Shell命令
启动客户端
1 |
bin/zkCli.sh |
显示所有操作命令
1 |
[zk: localhost:2181(CONNECTED) 0] help |
查看当前znode中所包含的内容
1 |
[zk: localhost:2181(CONNECTED) 1] ls / |
查看当前节点数据并能看到更新次数等数据
1 |
[zk: localhost:2181(CONNECTED) 2] ls2 / |
创建普通节点
1 |
[zk: localhost:2181(CONNECTED) 3] create /app1 "hello app1" |
获得节点的值
1 |
[zk: localhost:2181(CONNECTED) 5] get /app1 |
创建短暂节点
1 |
[zk: localhost:2181(CONNECTED) 7] create -e /app-emphemeral 8888 |
创建带序号的节点
1 |
# 先创建一个普通的根节点app2 |
修改节点数据值
1 |
[zk: localhost:2181(CONNECTED) 8] set /app1 999 |
节点的值变化监听
在datanode1主机上注册监听/app1节点数据变化
1 |
[zk: localhost:2181(CONNECTED) 9] get /app1 watch |
在datanode2主机上修改/app1节点的数据
1 |
[zk: localhost:2181(CONNECTED) 0] set /app1 777 |
datanode1主机上的变化
1 |
[zk: localhost:2181(CONNECTED) 10] |
节点的子节点变化监听(路径变化)
在datanode1主机上注册监听/app1节点的子节点变化
1 |
[zk: localhost:2181(CONNECTED) 0] ls /app1 watch |
在datanode2主机/app1节点上创建子节点
1 |
[zk: localhost:2181(CONNECTED) 1] create /app1/bb 666 |
观察datanode1主机收到子节点变化的监听
1 |
WATCHER:: |
删除节点
1 |
[zk: localhost:2181(CONNECTED) 2] delete /app1/bb |
递归删除节点
1 |
[zk: localhost:2181(CONNECTED) 3] rmr /app2 |
查看节点状态
1 |
[zk: localhost:2181(CONNECTED) 1] stat /app1 |
API应用
IDEA环境搭建
-
创建一个Maven工程
-
添加pom文件
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18<dependencies>
<dependency>
<groupId>junit</groupId>
<artifactId>junit</artifactId>
<version>RELEASE</version>
</dependency>
<dependency>
<groupId>org.apache.logging.log4j</groupId>
<artifactId>log4j-core</artifactId>
<version>2.8.2</version>
</dependency>
<!-- https://mvnrepository.com/artifact/org.apache.zookeeper/zookeeper -->
<dependency>
<groupId>org.apache.zookeeper</groupId>
<artifactId>zookeeper</artifactId>
<version>3.4.10</version>
</dependency>
</dependencies>
log4j.propertie
1 |
log4j.rootLogger=INFO, stdout |
创建ZooKeeper客户端
1 |
public class ZKDemo { |
创建子节点
1 |
//创建节点 |
1 |
[zk: localhost:2181(CONNECTED) 2] ls / |
判断节点是否存在
1 |
public void testExist() throws KeeperException, InterruptedException { |
循环监听
1 |
try { |
改变节点的内容
1 |
public void testSet() throws KeeperException, InterruptedException { |
1 |
[zk: localhost:2181(CONNECTED) 20] get /cainiaoqingfeng/bigdata |
监听器原理
过程
- 先要有一个main()线程
- 在main线程中创建Zookeeper客户端,这时就会创建两个线程,一个负责网络连接通信(connet),一个负责监听(listener)。
- 通过connect线程将注册的监听事件发送给Zookeeper。
- 在Zookeeper的注册监听器列表中将注册的监听事件添加到列表中。
- Zookeeper监听到有数据或路径变化,就会将这个消息发送给listener线程。
- listener线程内部调用了process()方法。
常见监听
2.常见的监听
(1)监听节点数据的变化:
1 |
get path [watch] |
(2)监听子节点增减的变化
1 |
ls path [watch] |
写数据
ZooKeeper 的写数据流程主要分为以下几步,如图所示:
流程
- 比如 Client 向 ZooKeeper 的 Server1 上写数据,发送一个写请求。
- 如果Server1不是Leader,那么Server1 会把接受到的请求进一步转发给Leader,因为每个ZooKeeper的Server里面有一个是Leader。这个Leader 会将写请求广播给各个Server,比如Server1和Server2, 各个Server写成功后就会通知Leader。
- 当Leader收到大多数 Server 数据写成功了,那么就说明数据写成功了。如果这里三个节点的话,只要有两个节点数据写成功了,那么就认为数据写成功了。写成功之后,Leader会告诉Server1数据写成功了。
- Server1会进一步通知 Client 数据写成功了,这时就认为整个写操作成功。ZooKeeper 整个写数据流程就是这样的。
服务器节点动态上下线
ZkServer
1 |
import org.apache.zookeeper.*; |
ZkClient
1 |
import org.apache.zookeeper.*; |
参考资料:尚硅谷Zookeeper