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

相关推荐
lucky_syq9 分钟前
深入Spark核心:Shuffle全剖析与实战指南
大数据·分布式·python·spark
GIOTTO情13 分钟前
技术深度拆解:Infoseek 媒体发布系统的分布式架构与自动化实现
分布式·架构·媒体
一个帅气昵称啊25 分钟前
在.NET中如何优雅的使用DotNetCore.CAP实现分布式事务,事件总线和消息最终一致性
分布式·微服务·.net
7***n7538 分钟前
后端在微服务中的Traefik
微服务·云原生·架构
o***Z44839 分钟前
后端在分布式中的服务调用
分布式
青衫码上行1 小时前
分布式版本控制系统Git的安装和使用
分布式·git·svn
u***27611 小时前
分布式监控Skywalking安装及使用教程(保姆级教程)
分布式·skywalking
m***92381 小时前
RabbitMQ 客户端 连接、发送、接收处理消息
分布式·rabbitmq·ruby
苦学编程的谢1 小时前
RabbitMQ_1_RabbitMQ概述
分布式·rabbitmq
openFuyao1 小时前
openFuyao两大核心项目获得GitCode G-Star认证 社区生态迈向成熟
人工智能·云原生·开源软件