zookeeper学习笔记

一、什么是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目录结构

1. bin :放置运行脚本和工具脚本,如果是 Linux 环境还会有有 zookeeper 的运行日志 zookeeper.out
2. conf zookeeper 默认读取配置的目录,里面会有默认的配置文件
3. contrib zookeeper 的拓展功能
4. dist-maven zookeeper maven 打包目录
5. docs
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值