ZooKeeper学习笔记(一): 快速入门,ZooKeeper是什么能用来做什么
Zookepper从设计模式角度来理解:是一个基于观察者模式设计的分布式服务管理框架,他负责储存和管理大家都关心的数据,然后接手观察者的注册,一旦这些数据的状态发生变化,ZooKeeper就将负责通知已经在ZooKeeper上注册的那些观察者作出相应的反应
ZooKeeper=文件系统+通知机制
ZooKeeper数据模型的结构和Unix文件系统很类似,整体上可以看作是一颗树,每一个节点称作一个ZNode. 每一个ZNode默认能够储存1MB的数据,每一个ZNode都可以通过其路径唯一标识
所以因为能够存储的内容是有限的,导致没有办法存储大量的数据
提供的服务包括: 统一命名服务, 统一配置管理, 统一集群管理, 服务器节点动态上下限, 软负载均衡等等.
统一命名服务
在分布式环境下,经常需要对应用或者服务进行统一命名,便于识别.
例如: IP不容易记住,而域名容易记住.比如有一个域名叫做www.azang.com但是这下面有很多个不同IP的服务器,但不同的请求访问这个域名的时候,ZooKeeper可以对这些请求进行分配.(这一点也可以使用nginx来实现)
统一配置管理
统一集群管理
服务器动态上下线
客户端能实时洞察到服务器上下线的变化
软负载均衡
在ZooKeeper中记录每台服务器的访问数,让访问数最少的服务器区处理最新的客户端请求(这个功能nginx也可以实现,在业务中根据不同的业务需求来使用不同的中间件)
举例子:
ZooKeeperService /service/某服务
- 192.168.100.1 访问数30
- 192.168.100.2 访问数20
- 192.168.100.3 访问数10
但有一个新的请求来的时候访问某服务的时候,则ZooKeeper会让192.168.100.3 去处理访问,因为他的访问数最少