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章节内容。

相关推荐
lin_dec+20 分钟前
Serverless:零成本按需计算的未来
云原生·serverless
2501_933329552 小时前
技术架构深度解析:Infoseek舆情监测系统的全链路设计与GEO时代的技术实践
开发语言·人工智能·分布式·架构
迷藏4943 小时前
**eBPF实战进阶:从零构建网络流量监控与过滤系统**在现代云原生架构中,**网络可观测性**和**安全隔离**已成为
java·网络·python·云原生·架构
刘~浪地球3 小时前
架构设计--事件驱动架构设计与实现(05)
云原生·系统架构·云计算
鬼先生_sir3 小时前
Zookeeper:从入门到精通
分布式·zookeeper·云原生
marsh02064 小时前
31 openclaw微服务架构实践:构建分布式系统
微服务·ai·云原生·架构·编程·技术
开心码农1号5 小时前
k8s中service和ingress的区别和使用
云原生·容器·kubernetes
huohuopro7 小时前
Hbase伪分布式远程访问配置
数据库·分布式·hbase
AI精钢8 小时前
为何智能体需要 Dreaming 来优化记忆?
人工智能·云原生·aigc
Francek Chen8 小时前
【大数据存储与管理】NoSQL数据库:01 NoSQL简介
大数据·数据库·分布式·nosql