01、Zookeeper 简介

Zookeeper 简介

  • 1.什么是 Zookeeper
  • 2.Zookeeper 的存储结构
  • 2.1.Znode
  • 2.2.Znode 节点类型
  • 3.监听通知机制

1.什么是 Zookeeper

  • Zookeeper 官网
  • Zookeeper 是 Apache 的一个分布式服务框架,是 Apache Hadoop 的一个子项目。官方文档上这么解释 Zookeeper,它主要是用来解决分布式应用中经常遇到的一些数据管理问题,如:统一命名服务、状态同步服务、集群管理、分布式应用配置项的管理等。
  • 简单来说 zookeeper=文件系统+监听通知机制

2.Zookeeper 的存储结构

 

2.1.Znode

  • 在 Zookeeper 中,znode 是一个跟 Unix 文件系统路径相似的节点,可以向节点存储数据或者获取数据
  • Zookeeper 底层是一套数据结构。这个存储结构是一个树形结构,其上的每一个节点,我们称之为“znode”
  • Zookeeper 中的数据是按照“树”结构进行存储的。而且 znode 节点还分为 4 中不同的类型。
  • 每一个 znode 默认能够存储 1MB 的数据(对于记录状态性质的数据来说,够了)
  • 可以使用 zkCli 命令,登录到 Zookeeper 上,并通过 ls、create、delete、get、set 等命令操作这些 znode 节点

2.2.Znode 节点类型

  • PERSISTENT-持久化目录节点
    客户端与 zookeeper 断开连接后,该节点依旧存在。
  • PERSISTENT_SEQUENTIAL-持久化顺序编号目录节点
    客户端与 zookeeper 断开连接后,该节点依旧存在,只是 Zookeeper 给该节点名称进行顺序编号
  • EPHEMERAL-临时目录节点
    客户端与 zookeeper 断开连接后,该节点被删除。
  • EPHEMERAL_SEQUENTIAL-临时顺序编号目录节点
    客户端与 zookeeper 断开连接后,该节点被删除,只是 Zookeeper 给该节点名称进行顺 序编号。

3.监听通知机制

  • Zookeeper 是使用观察者设计模式来设计的。当客户端注册监听它关心的目录节点时,当目录节点发生变化(数据改变、被删除、子目录节点增加删除)时,Zookeeper 会通知客户端