Zookeeper特点

  1. Zookeeper在读多写少的场合有非常好的性能表现
  2. Zookeeper将数据存储在内存中,从内存中读取数据不需要磁盘I/O,速度非常快
  3. Zookeeper放弃了强一致性要求,允许数据经过一个时间窗口达到一致。

Zookeeper文件系统

ZK为了保证低延时,在内存中维护了文件树结构,这个树结构中,只有叶子节点才能存放数据,ZK规定每个叶子节点只能存储1M的数据。这个特性决定了ZK只能存储少量的数据。


管理集群选举master

集群中每个节点在ZK中注册临时顺序节点时,ZK都会按其生成顺序为他生成一个id,id中最小的机器将被选为集群的leader,其他所有节点都在父节点注册watcher,一旦leader宕机导致与ZK失联,集群将捕获到这一变化,重新确认新的leader。


实现分布式锁

有两种实现:

  1. 集群中所有机器都去竞争创建某个节点,创建成功的机器相当于获取了这个锁
  2. 所有机器都去某个父节点下创建子节点,序号最小的机器获取锁

实现队列

  1. 同步队列:在指定目录下创建watcher,当监控到子节点数目达到指定值后,读取消费
  2. FIFO队列:读取序列号最小的节点进行消费

在此场景下,znode节点值存储的可能就是消息本身。


实现负载均衡

Zookeeper本身不具备负载均衡,需要间接实现

服务端在启动时在节点下注册临时节点,客户端从节点

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值