【zookeeper选举源码分析】

文章目录


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

启动或leader宕机选举leader流程

在这里插入图片描述

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

相关推荐

  1. Zookeeper分析ZooKeeperServer

    2024-01-02 07:30:04       47 阅读
  2. Zookeeper剖析:深入理解Leader选举机制

    2024-01-02 07:30:04       54 阅读
  3. zookeeper(05)数据存储

    2024-01-02 07:30:04       45 阅读

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-01-02 07:30:04       98 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-01-02 07:30:04       106 阅读
  3. 在Django里面运行非项目文件

    2024-01-02 07:30:04       87 阅读
  4. Python语言-面向对象

    2024-01-02 07:30:04       96 阅读

热门阅读

  1. Python中的os模块中的常用方法

    2024-01-02 07:30:04       45 阅读
  2. Zynq中spi、iic等协议配置器件

    2024-01-02 07:30:04       58 阅读
  3. 循环展开与Duff Device

    2024-01-02 07:30:04       68 阅读
  4. 阿里云服务器节省计划价格便宜_成本优化全解析

    2024-01-02 07:30:04       66 阅读
  5. OpenSSL provider

    2024-01-02 07:30:04       66 阅读
  6. 工具Git详解

    2024-01-02 07:30:04       54 阅读
  7. 构建Python的Windows整合包教程

    2024-01-02 07:30:04       67 阅读
  8. ARM AArch64的虚拟化(virtualization)详解(上)

    2024-01-02 07:30:04       58 阅读