zookeeper
ZooKeeper 的核心
CAP 理论:解决 CP。
ZooKeeper 是一个分布式的开源协调服务,主要用于解决分布式系统中的一致性问题。它提供了一个高可用、高性能的分布式协调系统,可以用于实现诸如分布式锁、配置管理、命名服务等功能。
一、主要特点
- 一致性: ZooKeeper 提供了强一致性的数据模型,所有的读写操作都是原子的、有序的,保证了数据的一致性。
- 高可用性: ZooKeeper 使用了多副本的数据存储机制,保证了系统的高可用性,即使部分节点宕机也不会影响系统的正常运行。
- 持久性: ZooKeeper 将数据存储在内存中,并通过持久化机制将数据写入磁盘,确保数据的持久性。
- 监控机制: ZooKeeper 提供了丰富的监控和管理机制,可以实时监控系统的状态和性能。
- 简单易用: ZooKeeper 提供了简单易用的 API,开发者可以轻松地实现分布式系统中的各种功能。
二、核心概念
- 节点(Node): ZooKeeper 中的数据单元,类似于文件系统中的目录或文件。
- ZNode: ZooKeeper 中的数据节点,存储了数据和元数据信息,每个 ZNode 都有一个唯一的路径。
- 会话(Session): 客户端与 ZooKeeper 服务器之间的连接会话,可以用来维护客户端的状态和会话信息。
- Watcher: 客户端可以注册 Watcher 监听某个 ZNode 的变化,当 ZNode 发生变化时会收到通知。
ZooKeeper 在分布式系统中有着广泛的应用,常用于实现分布式锁、配置管理、服务发现等功能,是构建可靠、高性能分布式系统的重要基础。