Zookeeper设计的思想

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

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

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

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

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

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

相关推荐
行者-全栈开发2 小时前
拆解高可用CRM网站的容灾设计与云原生实践
微服务·云原生·异地多活·监控告警·高可用设计·crm架构·容灾演练
阿维的博客日记3 小时前
分布式事务代码
分布式
Crazy________4 小时前
4.13docker仓库registry
mysql·算法·云原生·eureka
小义_19 小时前
【Kubernetes】(五) pod2
linux·云原生·容器·kubernetes
_waylau19 小时前
鸿蒙架构师修炼之道-面向对象的分布式架构
分布式·华为·架构·架构师·harmonyos·鸿蒙
雨奔20 小时前
Kubernetes 对象标识详解:Name、UID、Label
云原生·容器·kubernetes
Francek Chen21 小时前
【大数据存储与管理】NoSQL数据库:03 NoSQL与关系数据库的比较
大数据·数据库·分布式·nosql
老实巴交的麻匪1 天前
Exception异常架构设计:系统性异常处理的思维革命(05)
运维·云原生·架构
FeBaby1 天前
Java 高并发场景下 Redis 分布式锁(UUID+Lua)最佳实践
java·redis·分布式
VelinX1 天前
FastGPT本地部署及其使用
云原生·eureka