- Zookeeper在读多写少的场合有非常好的性能表现
- Zookeeper将数据存储在内存中,从内存中读取数据不需要磁盘I/O,速度非常快
- Zookeeper放弃了强一致性要求,允许数据经过一个时间窗口达到一致。
Zookeeper文件系统
ZK为了保证低延时,在内存中维护了文件树结构,这个树结构中,只有叶子节点才能存放数据,ZK规定每个叶子节点只能存储1M的数据。这个特性决定了ZK只能存储少量的数据。
管理集群选举master
集群中每个节点在ZK中注册临时顺序节点时,ZK都会按其生成顺序为他生成一个id,id中最小的机器将被选为集群的leader,其他所有节点都在父节点注册watcher,一旦leader宕机导致与ZK失联,集群将捕获到这一变化,重新确认新的leader。
实现分布式锁
有两种实现:
- 集群中所有机器都去竞争创建某个节点,创建成功的机器相当于获取了这个锁
- 所有机器都去某个父节点下创建子节点,序号最小的机器获取锁
实现队列
- 同步队列:在指定目录下创建watcher,当监控到子节点数目达到指定值后,读取消费
- FIFO队列:读取序列号最小的节点进行消费
在此场景下,znode节点值存储的可能就是消息本身。
实现负载均衡
Zookeeper本身不具备负载均衡,需要间接实现
服务端在启动时在节点下注册临时节点,客户端从节点