简介
zookeeper
(后文简称zk)提供功能有:服务注册中心、全局服务命名、以及分布式锁。
RPC服务会被发布到不同的服务器上,本项目zk的作用就是找到某一个RPC服务在哪一个服务器上,提供服务注册发现功能。
zk的数据如何组织?
znode
每个znode节点都只存储简单的byte
字节数组,一般存少量状态信息,默认数据上限为1MB,我们项目中用来存服务的IP:PORT
.
zk的Client常用的命令
Client常用的命令有ls
、get
、 create
、set
、delete
服务注册之后,注册中心和各个服务实例直接建立Session
,要求实例们定期发送心跳,有一个心跳计数(定时增加),收到实例心跳后心跳计数恢复,一旦心跳计数超过某一特定值,则认为实例挂了,删除该实例。
临时性ephemeral
节点,rpc节点超时未发送心跳消息,zk会自动删除临时性节点;
永久性节点,rpc节点超时未发送心跳消息,zk不会自动删除永久性节点。
zk会在在1/3的Timeout时间向服务提供方发送ping心跳消息,可以使用tcpdump
进行测试:sudo tcpdump -i lo port 2181
zookeeper安装和基本使用
tar -zxvf zookeeper-3.4.10.tar.gz
jyhlinux@ubuntu:~/share/zookeeper-3.4.10$ cd conf/
jyhlinux@ubuntu:~/share/zookeeper-3.4.10/conf$ mv zoo_sample.cfg zoo.cfg
使用vim修改zk的配置文件zoo.cfg
,将数据目录改为自己指定的路径
/home/jyhlinux/share/zookeeper-3.4.10/data
运行zk的Server
端程序(后台运行)
jyhlinux@ubuntu:~/share/zookeeper-3.4.10/bin$ ./zkServer.sh start
运行zk的Client
程序
jyhlinux@ubuntu:~/share/zookeeper-3.4.10/bin$ ./zkCli.sh
zk的Client常用的命令有:ls、get、 create、set 、delete
使用例子:
[zk: localhost:2181(CONNECTED) 0] ls /
[zookeeper]
# 查看 zookeeper目录 下有一个子节点 quota
[zk: localhost:2181(CONNECTED) 5] ls /zookeeper
[quota]
#获取 /zookeeper/quota节点信息, 数据长度为0,孩子数为0
[zk: localhost:2181(CONNECTED) 9] get /zookeeper/quota
cZxid = 0x0
ctime = Thu Jan 01 08:00:00 CST 1970
mZxid = 0x0
mtime = Thu Jan 01 08:00:00 CST 1970
pZxid = 0x0
cversion = 0
dataVersion = 0
aclVersion = 0
ephemeralOwner = 0x0
dataLength = 0
numChildren = 0
# 根目录下创建了mprpc节点,值为20
[zk: localhost:2181(CONNECTED) 10] create /mprpc 20
Created /mprpc
# zk删除父节点需要先把子节点删除
[zk: localhost:2181(CONNECTED) 2] create /mprpc/servic 22
Created /mprpc/servic
[zk: localhost:2181(CONNECTED) 3] delete /mprpc
Node not empty: /mprpc
[zk: localhost:2181(CONNECTED) 4] delete /mprpc/servic
[zk: localhost:2181(CONNECTED) 5] delete /mprpc
[zk: localhost:2181(CONNECTED) 6]
# zk不能一次创建多级目录,要逐级创建
[zk: localhost:2181(CONNECTED) 10] create /userServiceRpc 22
Created /userServiceRpc
[zk: localhost:2181(CONNECTED) 14] create /userServiceRpc/service_1/service_1_1 22
Node does not exist: /userServiceRpc/service_1/service_1_1
[zk: localhost:2181(CONNECTED) 15] create /userServiceRpc/service_1 11
Created /userServiceRpc/service_1
[zk: localhost:2181(CONNECTED) 16] create /userServiceRpc/service_1/service_1_1 22
Created /userServiceRpc/service_1/service_1_1
zk的原生开发API编译安装
~/share/zookeeper-3.4.10/src/c$ sudo ./configure
然后需要将Makefile文件中做修改,使gcc不要把编译警告当作错误
~/share/zookeeper-3.4.10/src/c$ sudo vim Makefile
保证下面红圈部分没有 -Werror
然后再执行以下步骤
~/share/zookeeper-3.4.10/src/c$ sudo make
~/share/zookeeper-3.4.10/src/c$ sudo make install