目录
1.Zookeeper 概述
Zookeeper 是一个开源的分布式协调服务,用于分布式应用程序中的数据管理和协调。它提供了一套简单而有效的原语,用于实现诸如配置管理、同步、组服务和命名等复杂的分布式系统任务。
核心功能
- 配置管理:集中管理配置数据,支持动态更新和通知。
- 命名服务:提供分布式命名和目录服务。
- 分布式锁:实现分布式环境中的锁机制。
- 集群管理:监控和管理分布式应用的节点状态。
- 领导选举:确保集群中只有一个活跃的主节点。
2.Zookeeper的架构
Zookeeper 的架构主要由以下几个组件组成:
- 服务器(Server):Zookeeper 集群中的节点,通常由多个服务器组成,以提供高可用性。
- 客户端(Client):与 Zookeeper 服务器交互的应用程序或服务。
- 会话(Session):客户端和服务器之间的连接,支持会话超时和重连机制。
- 数据节点(Znode):Zookeeper 中的数据存储单元,类似于文件系统中的节点。
3.工作原理
Zookeeper 采用一致性协议(如 ZAB 协议)来保证数据一致性。其核心工作原理包括:
- 写操作顺序:所有写操作按顺序执行,确保数据一致性。
- 读操作并发:读操作可以并发执行,提高系统性能。
- 原子性:所有操作要么成功,要么失败,不存在部分成功的情况。
Zookeeper 提供了严格的顺序一致性,所有客户端看到的数据变化顺序是一致的。同时,它还保证:
- 线性化读:读操作返回的结果是最近写入的数据。
- 线性化写:写操作按顺序执行,确保数据一致性。
4.基本操作
连接 Zookeeper:使用 zkCli.sh 工具连接到 Zookeeper 服务器
bin/zkCli.sh -server localhost:2181
常用命令:
# 创建节点
create /myapp "hello zookeeper"
# 获取节点数据
get /myapp
# 设置节点数据
set /myapp "new data"
# 删除节点
delete /myapp
# 多操作事务
multi
create /txn-1 "data1"
create /txn-2 "data2"
commit
# 条件更新
set /myapp "new data" 2