一、ZooKeeper简介
1. ZooKeeper是什么
Apache ZooKeeper是一个开源的分布式服务框架,为分布式应用提供协调服务,用来解决分布式应用中的数据管理问题,如:配置管理、域名服务、分布式同步、集群管理等
官网 https://zookeeper.apache.org/
ZooKeeper视频教程 http://edu.51cto.com/course/16190.html
2. ZooKeeper组成
主要包括两部分:文件系统、通知机制
2.1 文件系统
ZooKeeper维护一个类似Linux文件系统的数据结构,用于存储数据
- 数据模型结构是一种树形结构,由许多节点构成
- 每个节点叫做ZNode(ZooKeeper Node)
- 每个节点对应一个唯一路径,通过该路径来标识节点,如 /app1/p_2
- 每个节点只能存储大约1M的数据
节点类型有四种:
- 持久化目录节点 persistent
- 客户端与服务器断开连接,该节点仍然存在
- 持久化顺序编号目录节点 persistent_sequential
- 客户端与服务器断开连接,该节点仍然存在,此时节点会被顺序编号,如:000001、000002.....
- 临时目录节点 ephemeral
- 客户端与服务器断开连接,该节点会被删除
- 临时顺序编号目录节点 ephemeral_sequential
- 客户端与服务器断开连接,该节点会被删除,此时节点会被顺序编号,如:000001、000002.....
2.2 通知机制
ZooKeeper是一个基于观察者模式设计的分布式服务管理框架
- ZooKeeper负责管理和维护项目的公共数据,并授受观察者的注册(订阅)
- 一旦这些数据发生变化,ZooKeeper就会通知已注册的观察者
- 此时观察者就可以做出相应的反应
简单来说,客户端注册监听它关心的目录节点,当目录节点发生变化时,ZooKeeper会通知客户端
ZooKeeper是一个订阅中心(注册中心)
3. 应用场景
3.1 配置管理
场景:集群环境、服务器的许多配置都是相同的,如:数据库连接信息,当需要修改这些配置时必须同时修改每台服务器,很麻烦
解决:把这些配置全部放到ZooKeeper上,保存在ZooKeeper的某个目录节点中,然后所有的应用程序(客户端)对这个目录节点进行监视Watch,一旦配置信息发生变化,ZooKeeper会通知每个客户端,然后从ZooKeeper获取新的配置信息,并应用到系统中。
3.2 集群管理
场景:集群环境下,如何知道有多少台机器在工作?是否有机器退出或加入?需要选举一个总管master,让总管来管理集群
解决: