Zookeeper简介

1. 什么是Zookeeper

ZooKeeper is a high-performance coordination service for distributed applications. It exposes common services - such as naming, configuration management, synchronization, and group services - in a simple interface so you don't have to write them from scratch. You can use it off-the-shelf to implement consensus, group management, leader election, and presence protocols. And you can build on it for your own, specific needs.

ZooKeeper是分布式应用程序的高性能协调服务。它在一个简单的接口中公开了通用服务,如命名、配置管理、同步和组服务,因此您不必从头开始编写它们。您可以使用现成的工具来实现共识、组管理、领导者选举和出席协议。你可以根据自己的特定需求进行构建。

2. Zookeeper的设计目标

2.1 复制的

与它协调的分布式进程一样,ZooKeeper本身旨在集群主机之间的数据(配置)复制。

2.2 事务有序的

ZooKeeper用一个数字标记每次更新,该数字反映了所有ZooKeeper事务的顺序。后续操作可以使用该顺序来实现更高级别的抽象,例如同步原语。

2.3 高效的

它在"以读取为主"的工作负载中特别快。ZooKeeper应用程序在数千台机器上运行,在读取比写入更常见的情况下,其性能最佳,比率约为10:1。

3. Zookeeper的数据模型和分层命名空间

3.1 数据模型

Unlike standard file systems, each node in a ZooKeeper namespace can have data associated with it as well as children. It is like having a file-system that allows a file to also be a directory. (ZooKeeper was designed to store coordination data: status information, configuration, location information, etc., so the data stored at each node is usually small, in the byte to kilobyte range.) We use the term znode to make it clear that we are talking about ZooKeeper data nodes.

与标准文件系统不同,ZooKeeper命名空间中的每个节点都可以拥有与其关联的数据以及子节点。这就像有一个文件系统,允许文件也成为目录。(ZooKeeper旨在存储协调数据:状态信息、配置、位置信息等,因此存储在每个节点的数据通常很小,在字节到千字节的范围内。)我们使用术语znode来明确我们谈论的是ZooKeeper数据节点。

3.2 分层命名空间

2.1 服务发现

2.2 分布式配置

  • 配置文件的更新,借助zookeeper的znode变化,更新指定的配置文件或配置项。
  • 分布式环境中,同时更新所有集群机器上的配置文件。 参考 [[Zookeeper 官方示例2-SyncPrimitive 代码解读]] 第1章节内容。

2.3 Master的选举

2.4 消息队列(JMX)

参考[[Zookeeper 官方示例2-SyncPrimitive 代码解读]] 第2章节内容。

相关推荐
毕设源码-钟学长2 小时前
【开题答辩全过程】以 分布式菌菇销售系统为例,包含答辩的问题和答案
分布式
橙色云-智橙协同研发2 小时前
【PLM实施专家宝典】离散制造企业MBD与无纸化制造实施方案:从“图纸驱动”到“数据驱动”的革命
云原生·解决方案·数字化转型·plm·国产plm·专家经验·无纸化
victory04313 小时前
K8S重启之后无法启动故障排查 与 修复
云原生·容器·kubernetes
研究司马懿5 小时前
【ETCD】ETCD常用命令
网络·数据库·云原生·oracle·自动化·运维开发·etcd
千禧皓月9 小时前
【C++】基于C++的RPC分布式网络通信框架(二)
c++·分布式·rpc
杂家10 小时前
Zookeeper完全分布式部署(超详细)
大数据·分布式·zookeeper
悠闲蜗牛�11 小时前
技术融合新纪元:深度学习、大数据与云原生的跨界实践
大数据·深度学习·云原生
雨点保护雪花11 小时前
15、RabbitMQ
分布式·rabbitmq
徒 花11 小时前
Nginx
运维·nginx·云原生
回忆是昨天里的海12 小时前
k8s部署dashboard ui管理平台
云原生·容器·kubernetes