7.ZooKeeper数据模型
Zookeeper 会维护一个具有层次关系的数据结构,它非常类似于一个文件系统
Zookeeper 这种数据结构有如下这些特点:
●每个子目录项如NameService都被称作为znode,这个znode是被它所在的路径唯一标
识,如Server1 这个znode的标识为/NameService/Server1
●znode可以有子节点目录,并且每个znode可以存储数据,注意EPHEMERAL 类型的目
录节点不能有子节点目录
●znode是有版本的,每个znode中存储的数据可以有多个版本,也就是一个访问路径中
可以存储多份数据
●znode可以是临时节点,一旦创建这个znode的客户端与服务器失去联系,这个znode
也将自动删除,Zookeeper 的客户端和服务器通信采用长连接方式,每个客户端和服务器通过心跳来保持连接,这个连接状态称为session,如果znode是临时节点,这个session 失效,znode也就删除了
●znode的目录名可以自动编号,如App1 已经存在,再创建的话,将会自动命名为App2 ●znode可以被监控,包括这个目录节点中存储的数据的修改,子节点目录的变化等,一
旦变化可以通知设置监控的客户端,这个是Zookeeper 的核心特性,Zookeeper 的很多功能都是基于这个特性实现的,后面在典型的应用场景中会有实例介绍