zookeeper应用原理

本文详细介绍了ZooKeeper作为分布式协调服务的基本功能和应用场景,包括数据发布与订阅、命名服务、集群管理和分布式锁等核心特性,并探讨了其实现原理。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

一、 zookeeper是什么

分布式系统提供一致性协调(Coordination)服务。

二、zookeeper基本功能及应用

2.1 数据发布与订阅(配置中心)

把数据保存在 Zookeeper 的某个目录节点中,然后所有相关应用程序对这个目录节点进行监听,一旦配置信息发生变化,每个应用程序就会收到 Zookeeper 的通知,然后从 Zookeeper 获取新的配置信息应用到系统中就好。并且多个节点并发写的时候, 通过乐观锁(获取版本, 写得时候带入版本号就知道自己读的是不是过期数据)实现。

2.2 命名服务(Naming Service)

在zookeeper的文件系统里创建一个目录,即有唯一的path

2.3 集群管理与Master选举

所谓集群管理无在乎两点:是否有机器退出和加入、选举master。
对于第一点,所有机器约定在父目录GroupMembers下创建临时目录节点,然后监听父目录节点的子节点变化消息。一旦有机器挂掉,该机器与 zookeeper的连接断开,其所创建的临时目录节点被删除,所有其他机器都收到通知:某个兄弟目录被删除,于是,所有人都知道:它上船了。新机器加入 也是类似,所有机器收到通知:新兄弟目录加入,highcount又有了。
对于第二点,我们稍微改变一下,所有机器创建临时顺序编号目录节点,每次选取编号最小的机器作为master就好。

2.4 分布式锁

在zookeeper的文件系统里创建一个目录,即有唯一的path
通过乐观锁获取数据内容(资源数量)

三、 zookeeper实现原理

3.1 选举阶段

根据id保证网络顺序, 得到候选人资格(数据全的id大一些)

3.2 确认阶段

确认自己是leader

3.3 广播

注:转载https://blog.youkuaiyun.com/gs80140/article/details/51496925

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值