1500字简述 Apache ZooKeeper 的基本原理

本文涉及的产品
云原生网关 MSE Higress,422元/月
服务治理 MSE Sentinel/OpenSergo,Agent数量 不受限
注册配置 MSE Nacos/ZooKeeper,118元/月
简介: Apache有个非常棒的开源项目叫做Zookeeper,用于管理大量主机的分布式协调服务,很多人对Zookeeper的原理不太了解,那么本文瑞哥就带大家学习一下Zookeeper的基本原理。

你好,这里是网络技术联盟站。

Apache有个非常棒的开源项目叫做Zookeeper,用于管理大量主机的分布式协调服务,很多人对Zookeeper的原理不太了解,那么本文瑞哥就带大家学习一下Zookeeper的基本原理。

什么是Zookeeper?

ZooKeeper 是对分布式环境中大量主机的协调和管理服务,是一个框架,ZooKeeper 框架最初是由 Yahoo! 构建的。

我们都知道在分布式环境中协调和管理服务确实是一个非常复杂的过程,但是 ZooKeeper 以其简单的架构和 API 解决了这个问题。

什么是分布式服务?

提到ZooKeeper,那么一定得提到分布式服务,ZooKeeper是专门为分布式服务设计的。

简单来说,分布式系统就是多台设备、多个服务的集合,这个集合对外看起来就是单台服务,这些内部的多台服务相互配合、容错、共享、协同完成分布式服务,单台设备的故障不会影响整个系统的运行。

分布式系统有以下好处:

  1. 扩展性:分布式系统可以水平扩展,达到使用更多的流量。
  2. 模块化:分布式系统可以扩展多个模块,而且一般都没有上限。
  3. 容错性:分布式系统比单机更容错。
  4. 成本效益:初始成本高于传统系统,但由于其可扩展性,扩展的越多、时间越长,其成本效益就很高。
  5. 低延迟:用户可以在多个位置拥有一个节点
  6. 效率高:分布式系统将复杂数据分解成更小的部分,所以处理效率一般都很高。

ZooKeeper 架构

ZooKeeper 在客户端-服务器架构上工作:

我们来看下ZooKeeper这些角色:

  • Client:客户端用于访问来自服务器的信息,它向服务器发送一条消息,让服务器知道客户端还活着,如果连接的服务器没有响应,客户端会自动将消息重新发送到另一台服务器。
  • Server:服务器向客户端发出确认以通知服务器处于活动状态,并向客户端提供所有服务。
  • Leader:如果任何服务器节点发生故障,该服务器节点将执行自动恢复。
  • Follower:追随Leader指示的服务器节点。

## ZooKeeper如何工作?

  • ZooKeeper 服务器启动后发生的第一件事是,它等待客户端连接到服务器。
  • ZooKeeper 集群中的客户端将连接到其中一个节点,该节点可以是Leader或Follower中的任何一个。
  • 一旦客户端连接到特定节点,该节点就会将会话 ID 分配给客户端并向该特定客户端发送确认。
  • 如果客户端没有从节点得到任何确认,那么它会将消息重新发送到 ZooKeeper 集群中的另一个节点并尝试与之连接。
  • 收到确认后,客户端通过定期向节点发送心跳来确保连接不会丢失。
  • 最后,客户端可以根据需要执行读取、写入或存储数据等功能。

最好使用奇数个服务器运行 ZooKeeper 集群;典型的集群大小是3、5或7。例如,如果运行 5 台服务器,假如其中 3 台停机,则集群将不可用,这个时候可以让一台服务器停机进行维护,但仍能在故障中恢复。但是,如果运行 6 台服务器,集群在发生 3 次故障后仍然不可用,但同时发生 3 次故障的可能性现在略高一些。当添加更多服务器时,虽然可以容忍更多故障,但这也会让吞吐量降低。

ZooKeeper用途

ZooKeeper一般有两个用途:

  • 分布式文件系统
  • 消息队列

分布式文件系统

ZooKeeper 中信息的组织方式与文件系统非常相似,在顶部有一个根,简称为 /,在根之下有称为 zNodes 的节点,是 ZooKeeper 节点的缩写,但主要是用于避免与计算机节点混淆的术语,一个 zNode 既可以充当包含二进制数据的文件,也可以充当具有更多 zNode 作为子节点的目录,与大多数文件系统一样,每个 zNode 都有一些元数据,该元数据包括读写权限版本信息

与普通的分布式文件系统不同,ZooKeeper 支持临时 zNode 和顺序 zNode 的概念,临时 zNode 是一个在其所有者的会话结束时将消失的节点,临时节点的典型用例是使用 ZooKeeper 发现分布式系统中的主机,然后,每个服务器都可以在临时节点中发布其 IP 地址,并且如果服务器与 ZooKeeper 失去连接并且无法在会话超时内重新连接,则其信息将被删除。

消息队列

ZooKeeper 可以在 zNode 上注册观察者,通过使用观察者,可以通过让所有对某个主题感兴趣的客户端在该主题的 zNode 上注册一个观察者来实现消息队列,并且可以通过写入该 zNode 将有关该主题的消息广播给所有客户端,其实也就是观察者订阅某个主题。

不过,观察者总是一次性的,所以如果你想进一步更新那个 zNode,必须重新注册它们,在接收更新和重新注册之间会丢失更新,但可以通过使用 zNode 的版本号检测到这一点。

总结

Apache ZooKeeper 是一个开源 Apache 项目,主要用于大型集群系统上进行分发配置、命名和组服务,使得分布式系统更易于管理,本文用1500来字简述了ZooKeeper的工作,希望对您有所帮助。

最后感谢您的阅读,如果觉得文章对您有帮助,别忘了点赞👍、收藏⭐哦!有任何问题,欢迎在下方评论区与我讨论!!!

相关实践学习
基于MSE实现微服务的全链路灰度
通过本场景的实验操作,您将了解并实现在线业务的微服务全链路灰度能力。
目录
相关文章
|
12天前
|
SQL 存储 数据处理
别让你的CPU打盹儿:Apache Doris并行执行原理大揭秘!
别让你的CPU打盹儿:Apache Doris并行执行原理大揭秘!
54 1
别让你的CPU打盹儿:Apache Doris并行执行原理大揭秘!
|
2月前
|
SQL 存储 数据处理
兼顾高性能与低成本,浅析 Apache Doris 异步物化视图原理及典型场景
Apache Doris 物化视图进行了支持。**早期版本中,Doris 支持同步物化视图;从 2.1 版本开始,正式引入异步物化视图,[并在 3.0 版本中完善了这一功能](https://www.selectdb.com/blog/1058)。**
|
3月前
|
存储 分布式计算 druid
大数据-155 Apache Druid 架构与原理详解 数据存储 索引服务 压缩机制
大数据-155 Apache Druid 架构与原理详解 数据存储 索引服务 压缩机制
78 3
|
3月前
|
消息中间件 分布式计算 druid
大数据-154 Apache Druid 架构与原理详解 基础架构、架构演进
大数据-154 Apache Druid 架构与原理详解 基础架构、架构演进
80 2
|
3月前
|
分布式计算 负载均衡 算法
Hadoop-31 ZooKeeper 内部原理 简述Leader选举 ZAB协议 一致性
Hadoop-31 ZooKeeper 内部原理 简述Leader选举 ZAB协议 一致性
37 1
|
3月前
|
分布式计算 监控 Hadoop
Hadoop-29 ZooKeeper集群 Watcher机制 工作原理 与 ZK基本命令 测试集群效果 3台公网云服务器
Hadoop-29 ZooKeeper集群 Watcher机制 工作原理 与 ZK基本命令 测试集群效果 3台公网云服务器
54 1
|
3月前
|
负载均衡 应用服务中间件 Apache
Tomcat负载均衡原理详解及配置Apache2.2.22+Tomcat7
Tomcat负载均衡原理详解及配置Apache2.2.22+Tomcat7
66 3
|
5月前
|
数据采集 分布式计算 Kubernetes
Apache Flink 实践问题之ZooKeeper 网络瞬断时如何解决
Apache Flink 实践问题之ZooKeeper 网络瞬断时如何解决
123 4
|
5月前
|
分布式计算 监控 Hadoop
详解 Apache ZooKeeper 和 Apache Oozie
【8月更文挑战第31天】
143 0
|
8月前
|
Java API Apache
ZooKeeper【基础 03】Java 客户端 Apache Curator 基础 API 使用举例(含源代码)
【4月更文挑战第11天】ZooKeeper【基础 03】Java 客户端 Apache Curator 基础 API 使用举例(含源代码)
81 11

热门文章

最新文章

推荐镜像

更多