Zookeeper设计的思想

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

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

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

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

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

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

相关推荐
中议视控1 小时前
RTSP和RTSM编码推送软件让中控系统控制实现可视化播控
网络·分布式·物联网·5g·音视频
Thomas.Sir5 小时前
深入剖析 Redis 经典面试题
redis·分布式·高并发·
阿里云云原生5 小时前
【昨晚 17:00】模力工场联合 HiClaw,聊聊怎么把虾场管明白
云原生
十点就想睡7 小时前
redission分布式锁的介绍及使用
分布式
阿里云云原生8 小时前
连登顶会!阿里云多项研究成果大幅提升运维智能精度与效率
云原生
阿里云云原生8 小时前
从养一只虾到开好虾场,HiClaw 规模化养虾的详细解读
云原生
`Jay9 小时前
Python Redis连接池&账号管理池
redis·分布式·爬虫·python·学习
河码匠10 小时前
Kubernests YAML 详细之卷(PV、PVC、StorageClass)
云原生·容器·kubernetes
码上上班11 小时前
k8s控制器,daemonset
云原生·容器·kubernetes
rannn_11111 小时前
【Redis|实战篇4】黑马点评|分布式锁
java·数据库·redis·分布式·后端