Zookeeper设计的思想

ZooKeeper设计的目的是提供高性能、高可用、顺序一致性的分布式协调服务、保证数据最终一致性。

高性能(简单的数据模型)

1: 采用树形结构组织数据节点;
2: 全量数据节点,都存储在内存中;
3: Follower 和 Observer 直接处理非事务请求;

高可用(构建集群)
1: 半数以上机器存活,服务就能正常运行
2: 自动进行 Leader 选举

顺序一致性(事务操作的顺序)
1: 每个事务请求,都会转发给 Leader 处理
2: 每个事务,会分配全局唯一的递增id(zxid,64位:epoch + 自增 id)

最终一致性
1: 通过提议投票方式,保证事务提交的可靠性
2: 提议投票方式,只能保证 Client 收到事务提交成功后,半数以上节点能够看到最新数据

相关推荐
无心水13 小时前
2025,一路有你!
java·人工智能·分布式·后端·深度学习·架构·2025博客之星
懒神降世14 小时前
基于iVentoy的PXE服务器的部署实战指南
运维·服务器·开发语言·云原生·vmware·openeuler·iventoy
江畔何人初15 小时前
LVM中物理卷、物理区块、卷组、逻辑卷的概念以及它们之间的关系
linux·运维·云原生·容器·kubernetes
彷徨的蜗牛15 小时前
架构进阶:微服务拆分的“生死线”
微服务·云原生·架构
egzosn15 小时前
Eureka 的介绍和使用
云原生·eureka
canjun_wen15 小时前
Nacos基础入门 03,Nacos vs Eureka vs Consul:主流服务注册中心深度对比测评
云原生·eureka·consul
liu****15 小时前
4.镜像仓库详解
c++·docker·云原生·容器·kubernetes·镜像\
A-刘晨阳16 小时前
K8S 之 Taints(污点)与 Tolerations(容忍)
运维·云原生·容器·kubernetes·k8s污点·k8s容忍
打工的小王17 小时前
消息队列之Kafka(一)搭建服务
分布式·kafka
市安18 小时前
基于Debain构建Ngxin镜像
运维·nginx·docker·云原生·容器·debian·镜像