Zookeeper设计的思想

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

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

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

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

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

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

相关推荐
爬山算法4 小时前
Redis(167)如何使用Redis实现分布式缓存?
redis·分布式·缓存
NPE~4 小时前
面试高频——分布式事务详解
分布式·面试·职场和发展·程序员·事务·分布式事务
西岭千秋雪_4 小时前
MySQL集群搭建
java·数据库·分布式·mysql
❀͜͡傀儡师4 小时前
K8s 部署Doris 高可用集群
云原生·容器·kubernetes
星哥说事4 小时前
服务网格:Istio / Linkerd 流量管理与监控解析*
云原生·istio
櫻花6 小时前
微服务各大组件总结
微服务·云原生·架构
-大头.6 小时前
微服务架构深度演进与实践指南
微服务·云原生·架构
源代码•宸7 小时前
分布式缓存-GO(项目整体架构简介、Ubuntu 22.04 64位安装GoLang、安装Docker、解决Go module 的依赖问题)
经验分享·分布式·后端·ubuntu·缓存·docker·golang
Henry Zhu1237 小时前
VPP中FIB(转发信息库)和VRF(虚拟路由转发)详解:从设计理念到实际应用
网络·计算机网络·云原生·云计算·智能路由器
Ttang237 小时前
【SpringCloud1】从单体架构到分布式系统架构
分布式·spring cloud·架构