Zookeeper设计的思想

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

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

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

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

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

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

相关推荐
hwj运维之路6 分钟前
Docker面试题汇总系列
运维·docker·云原生·容器
Go高并发架构_王工16 分钟前
Kafka Streams:流处理应用开发实战
分布式·kafka·linq
Rysxt_22 分钟前
分布式数据库模式结构完整教程
数据库·分布式
Gold Steps.36 分钟前
Longhorn分布式云原生块存储系统
分布式·云原生
想你依然心痛1 小时前
Spark大数据分析与实战笔记(第六章 Kafka分布式发布订阅消息系统-03)
笔记·分布式·spark·kafka
hwj运维之路1 小时前
超详细ubuntu22.04部署k8s1.28高可用(一)【多master+keepalived+nginx实现负载均衡】
运维·云原生·kubernetes·负载均衡
鸽鸽程序猿1 小时前
【JavaEE】【SpringCloud】分布式事务 Alibaba Seata
分布式·spring cloud·java-ee
VermiliEiz1 小时前
使用二进制方式部署k8s(6)
云原生·容器·kubernetes
牛奶咖啡131 小时前
Prometheus+Grafana构建云原生分布式监控系统(十四)_Prometheus中PromQL使用(一)
云原生·prometheus·promql·计算一个时间范围内的平均值·将相同数据整合查看整体趋势·计算时间范围内的最大最小比率·向量标量的算术运算
王锋(oxwangfeng)2 小时前
Spark 向量化执行引擎技术选型与实践指南
大数据·分布式·spark