Java高频面试题- 每日三连问?【Day25】 — ZooKeeper篇(一)

2022-04-12 14:15:02 浏览数 (1)

问题导读

一、说说ZooKeeper 是什么?

二、ZooKeeper 提供了什么?

三、Zookeeper 文件系统

01

说说ZooKeeper 是什么?

正经回答:

ZooKeeper 是一个开放源码的分布式协调服务,它是集群的管理者,监视着集 群中各个节点的状态根据节点提交的反馈进行下一步合理操作。

最终,将简单易用的接口和性能高效、功能稳定的系统提供给用户。

分布式应用程序可以基于 Zookeeper 实现诸如数据发布/订阅、负载均衡、命名服务、分布式协调/通知、集群管理、Master 选举、分布式锁和分布式队列等功能。

Zookeeper 保证了如下分布式一致性特性:

(1)顺序一致性

(2)原子性

(3)单一视图

(4)可靠性

(5)实时性(最终一致性)

客户端的读请求可以被集群中的任意一台机器处理,如果读请求在节点上注册 了监听器,这

个监听器也是由所连接的 zookeeper 机器来处理。

对于写请求, 这些请求会同时发给其他zookeeper 机器并且达成一致后,请求才会返回成 功。

因此,随着 zookeeper 的集群机器增多,读请求的吞吐会提高但是写请求的吞吐会下降。

有序性是 zookeeper 中非常重要的一个特性,所有的更新都是全局有序的,每个更新都有一个唯一的时间戳,这个时间戳称为 zxid(Zookeeper Transaction Id)。

而读请求只会相对于更新有序,也就是读请求的返回结果中会带有这个 zookeeper 最新的 zxid。

分享朋友圈,每天进步一点点~

02

ZooKeeper 提供了什么?

正经回答:

 文件系统

 通知机制

03

Zookeeper 文件系统

正经回答:

Zookeeper 提供一个多层级的节点命名空间(节点称为 znode)。

与文件系统 不同的是,这些节点都可以设置关联的数据,而文件系统中只有文件节点可以 存放数据而目录节点不行。

Zookeeper 为了保证高吞吐和低延迟,在内存中维护了这个树状的目录结构, 这种特性使得 Zookeeper 不能用于存放大量的数据,每个节点的存放数据上限为 1M。

- End -

0 人点赞