Zookeeper设计的思想

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

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

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

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

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

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

相关推荐
孟意昶39 分钟前
Doris专题17- 数据导入-文件格式
大数据·数据库·分布式·sql·doris
会跑的葫芦怪2 小时前
RabbitMQ全面详解:从核心概念到企业级应用
java·分布式·rabbitmq
熙客2 小时前
阿里云负载均衡SLB的使用
网络·阿里云·云原生·云计算·负载均衡
clownAdam3 小时前
gaussdb数据库的集中式和分布式
数据库·分布式·gaussdb
_清浅3 小时前
大数据平台基础(Hadoop大数据原理与应用)
大数据·hadoop·分布式
翰林小院7 小时前
【RabbitMQ】 RabbitMQ Overview
分布式·rabbitmq
失散1312 小时前
分布式专题——39 RocketMQ客户端编程模型
java·分布式·架构·rocketmq
一个尚在学习的计算机小白13 小时前
RabbitMQ
分布式·rabbitmq
Cloud孙文波14 小时前
探索Apache APISIX:动态高性能API网关
云原生·kubernetes·apisix
奥尔特星云大使14 小时前
MySQL分布式架构:MyCat详解
数据库·分布式·mysql·mycat·高可用