Zookeeper设计的思想

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

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

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

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

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

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

相关推荐
阿里云云原生13 小时前
阿里云获评 Agentic AI 开发平台领导者,函数计算 AgentRun 赢下关键分!
云原生
初次攀爬者13 小时前
ZooKeeper 实现分布式锁的两种方式
分布式·后端·zookeeper
阿里云云原生20 小时前
MSE Nacos Prompt 管理:让 AI Agent 的核心配置真正可治理
微服务·云原生
阿里云云原生1 天前
当 AI Agent 接管手机:移动端如何进行观测
云原生·agent
阿里云云原生1 天前
AI 原生应用开源开发者沙龙·深圳站精彩回顾 & PPT下载
云原生
阿里云云原生1 天前
灵感启发:日产文章 100 篇,打造“实时热点洞察”引擎
云原生
~莫子1 天前
Haproxy七层负载详解+实验详细代码
云原生
阿里云云原生1 天前
OpenTelemetry + 云监控 2.0:打造你的云原生全栈可观测
云原生
阿狸猿1 天前
云原生数据库
云原生·软考
至此流年莫相忘1 天前
Kubernetes实战篇之配置与存储
云原生·容器·kubernetes