ZooKeeper是一个开发源码的分布式协调服务,他是集群的管理者,监视着集群中各个节点的状态提交反馈进行下一步合理的操作。最终,将简单易用的接口和性能高效功能稳定的系统提供给用户。
分布式应用程序可以基于ZooKeeper实现诸如数据发布、订阅、负载均匀、命名服务、分布式协调、通知、集群管理、Master选举、分布式锁和分布式队列等功能。
特性:顺序一致性,原子性,单一视图,靠谱性,实时姓最终一致性
客户端请求的读取可以被集群中的任意一台机器处理,如果读请求在节点上注册了监听器,这个监听器也是由所链接的ZooKeeper机器来处理。对于写请求,这些请求会同时发给其他ZooKeeper机器并且达成一致后,请求才会返回成功。因此,随着ZooKeeper的集群机器便变多,请求的吞吐会提高但是写请求的吞吐回下降。
有序行是ZooKeeper中的非常主要的一个特性,所有的更新都是全局有序的,每个更新都有一个唯一的时间戳,这个时间戳成为zxid,而读请求只会相对于更新有序,也就是读请求的返回结果会带来这个ZooKeeper最新的zxid。



