简述Zookeeper

Zookeeper为分布式应用提供了一个高效可靠的分布式协调服务,提供了诸如统一命名服务、配置管理和分布式锁等分布式的基础服务。它的实现是依赖于ZAB协议,实现了一种主备模式(master-slave)的架构来保持集群中数据的一致性。Zookeeper使得分布式应用可以通过一个共享的树形结构的命名空间实现协调,且zookeeper将全量数据存储在内存中,以此来实现提高服务器的吞吐、减少延迟的目的。由于zookeeper将全量数据存储在内存中,并且直接服务于客户端的所有非事务请求,因此它尤其适合以读操作为主的应用场景。

zookeeper集群中包括三个角色:Leader、Follow、Observer。其中Leader是通过选举确定的一台机器,为客户端提供读写功能,一个集群同一时间只能有一个实际上的Leader。Follow和Observer一样,在不影响写性能的前提下提升集群的读性能,但Follow会参加Leader的选举,Observer不会参加任何的投票。Zookeeper集群节点的数量为奇数个。它的节点有三种类型,分别是临时节点、持久节点和顺序节点。

最重要的功能是Watcher数据变更通知的功能,它是Zookeeper的核心功能。Watcher可以监控目录节点的数据变化以及子目录节点的变化,一旦这些状态发生变化时,服务器就会通知所有设置在这个目录节点上的watcher,从而每个客户端都很快知道它所关注的目录节点的状态,从而做出相应的反应。

它的应用场景有:统一命名服务,集群管理,master选举,分布式屏障、分布式队列、分布式锁、分布式协调/通知等。

二、为什么选择zookeeper?

首先,zookeeper无论从性能、易用性还是稳定性来说,都已经达到了一个工业级产品的标准。在解决分布式数据一致性上,除了zookeeper外,目前还没有一个成熟稳定且被大规模应用的解决方案。

其次zookeeper是开放源代码的,同时也是免费的,目前已经有越来越多的大型分布式项目将zookeeper作为其核心组件,如Hadoop、HBase、Solr等。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值