Zookeeper选举Leader源码剖析(上)

为什么要看源码:
1、 提升技术功底: 学习源码里的优秀设计思想,比如一些疑难问题的解决思路,还有一些优秀的设计模式,整体提升自己的技术功底
2、 深度掌握技术框架: 源码看多了,对于一个新技术或框架的掌握速度会有大幅提升,看下框架demo大致就能知道底层的实现,技术框架更新再快也不怕
3、 快速定位线上问题: 遇到线上问题,特别是框架源码里的问题(比如bug),能够快速定位,这就是相比其他没看过源码的人的优势
4、 知其然知其所以然: 对技术有追求的人必做之事,使用了一个好的框架,很想知道底层是如何实现的
看源码方法:
1、 先使用: 先看官方文档快速掌握框架的基本使用
2、 抓主线: 找一个demo入手,顺藤摸瓜快速静态看一遍框架的主线源码,画出源码主流程图,切勿一开始就陷入源码的细枝末节,否则会把自己绕晕,凭经验猜
3、 画图做笔记: 总结框架的一些核心功能点,从这些功能点入手深入到源码的细节, 边看源码边画源码走向图 ,并对关键源码的理解做
笔记,把源码里的闪光点都记录下来,后续借鉴到工作项目中,理解能力强的可以直接看静态源码,也可以边看源码边debug源码执行过程,观察一些关键变量的值
4、 整合总结: 所有功能点的源码都分析完后,回到主流程图再梳理一遍,争取把自己画的所有图都在脑袋里做一个整合
从源码启动zookeeper
zookeeper源码下载地址:

源码导入idea后,org.apache.zookeeper.Version类会报错,需要建一个辅助类

然后在根目录编译执行:

开源项目找入口类一般都是从启动脚本去找,可以从bin目录下的zkServer.sh或zkServer.cmd里找到启动主类运行即可

注意
1、将conf文件夹里的zoo_sample.cfg文件复制一份改名为zoo.cfg,将zoo.cfg文件位置配置到启动参数里

2、启动之前需要先将zookeeper-server项目里pom.xml文件里依赖的包(除了jline)的scope为provided这一行全部注释掉
2、将conf文件夹里的log4j.properties文件复制一份到zookeeper-server项目的 \target\classes 目录下,这样项目启动时才会打印日志
用客户端命令连接源码启动的server:

从源码里运行客户端( org.apache.zookeeper.ZooKeeperMain ),注意需要加入启动参数,见下图:


从源码启动zookeeper集群(参考视频讲解)
复制3个zoo.cfg文件,修改对应集群配置,并在data目录里分别建各自的myid文件填入机器id,并创建三个不同配置的启动节点,见下图:

分别运行每个节点,集群启动完毕!
启动或leader宕机选举leader流程

leader选举多层队列架构
整个zookeeper选举底层可以分为选举应用层和消息传输层,应用层有自己的队列统一接收和发送选票,传输层也设计了自己的队列,但是按发送的机器分了队列,避免给每台机器发送消息时相互影响,比如某台机器如果出问题发送不成功则不会影响对正常机器的消息发送。

Leader选举源码流程图

相关推荐
我好饿17 分钟前
部署k8s集群+containerd+dashboard
云原生·容器·kubernetes
济南java开发,求内推38 分钟前
两台服务器搭建三个节点
云原生·eureka
阿里云云原生38 分钟前
2025 云栖精选资料:《从云原生到 AI 原生核心技术与最佳实践》PPT 免费下载
云原生
不会写代码的加加1 小时前
告别重构噩梦:基于 Oinone 实现单体到微服务的平滑演进
spring boot·分布式
阿里云云原生2 小时前
SLS Copilot 实践:基于 SLS 灵活构建 LLM 应用的数据基础设施
云原生
szxinmai主板定制专家2 小时前
RK3588+AI算力卡替代英伟达jetson方案,大算力,支持FPGA自定义扩展
arm开发·人工智能·分布式·fpga开发
Vio7253 小时前
Eureka注册中心
云原生·eureka
Yeats_Liao4 小时前
遗留系统微服务改造(二):数据迁移实战攻略与一致性保证
微服务·云原生·架构
野蛮人6号4 小时前
黑马微服务P3快速入门入门案例无法跑通解决方案,本文解决了数据库连接和java版本不匹配的问题
微服务·云原生·架构
Pota-to成长日记5 小时前
Redisson 看门狗机制深度解析:分布式锁的守护者
分布式·wpf