一、什么是zookeeper
zookeeper官网: https://zookeeper.apache.org/
zookeeper是apache的一个分布式服务框架,是apache hadoop的一个子项目,官方文档上这么解释zookeeper,它主要是用来解决分布式应用中经常遇到的一些数据管理问题,如:统一命名服务 状态同步服务 集群管理 分布式应用配置项的管理等
简单来说 zookeeper=文件系统+监听通知机制
Zookeeper从设计模式角度来理解:是一个基于观察者模式设计的分布式服务管理框架,它负责存储和管理大家都关心的数据,然后接受观察者的注册,一旦这些数据的状态发生变化,Zookeeper就将负责通知已经在Zookeeper上注册的那些观察者做出相应的反应。
二、zookeeper的存储结构
1.znode
在Zookeeper中, znode是一个跟Unix文件系统路径相似的节点,可以向节点存储数据或者获取数据。
Zookeeper底层是一套数据结构。这个存储结构是一个树形结构,其上的每一个节点,我们称之为“znode"
zookeeper中的数据是按照“树”结构进行存储的。而且znode节点还分为4中不同的类型。
每一个znode默认能够存储1MB的数据(对于记录状态性质的数据来说,够了)
可以使用zkCli命令,登录到zookeeper上,并通过ls、create、delete、get、set来操作节点
2.znode类型
2.1 PERSISTENT-持久化目录节点
客户端与zookeeper断开连接后,该节点依旧存在。
2.2 PERSISTENT_SEQUENTIAL-持久化顺序编号目录节点
客户端与zookeeper断开连接后,该节点依旧存在,只是Zookeeper给该节点名称进行顺序编号
2.3 EPHEMERAL-临时目录节点
客户端与zookeeper断开连接后,该节点被删除。
2.4 EPHEMERAL SEQUENTIAL-l临时顺序编号目录节点
客户端与zookeeper断开连接后,该节点被删除,只是Zookeeper给该节点名称进行顺序编号
三、监听通知机制
Zookeeper是使用观察者设计模式来设计的。当客户端注册监听它关心的目录节点时,当目录节点发生变化(数据改变、被删除、子目录节点增加删除)时,Zookeeper会通知客户端。
四、安装
1.官方版本可在https://zookeeper.apache.org/releases.html站点中下载安装
2.解压
3.配置JDK [/etc/profile]
五、zookeeper目录结构