Zookeeper设计的思想

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

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

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

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

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

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

相关推荐
运维全栈笔记4 小时前
K8S部署WordPress+MySQL:模块化YAML配置详解
服务器·mysql·docker·云原生·容器·kubernetes·服务发现
大G的笔记本4 小时前
分布式事务
分布式
weixin_419658314 小时前
RabbitMQ 的高级特性
java·分布式·rabbitmq
_F_y5 小时前
仿RabbitMQ实现消息队列-服务端核心模块实现(1)
分布式·rabbitmq
眷蓝天5 小时前
k8s-pod资源对象实验
云原生·容器·kubernetes·pod资源对象
.柒宇.7 小时前
RabbitMQ入门教程
分布式·rabbitmq
代码漫谈8 小时前
RabbitMQ 单节点部署指南
分布式·消息队列·rabbitmq
TE-茶叶蛋8 小时前
微服务下 DTO 设计核心原则
微服务·云原生·架构
A-刘晨阳8 小时前
K8s 之 Ingress 及 Ingress Controller
云原生·容器·kubernetes·负载均衡·ingress
aLTttY8 小时前
Spring Boot + Redis 实战分布式锁:从入门到精通
spring boot·redis·分布式