Zookeeper(四)源码解析

本文涉及的产品
云解析 DNS,旗舰版 1个月
全局流量管理 GTM,标准版 1个月
服务治理 MSE Sentinel/OpenSergo,Agent数量 不受限
简介: Zookeeper(四)源码解析

源码构建

源码地址:https://github.com/apache/zookeeper

  1. 使用git clone 源码
  2. 选择分支,我这里选择的是3.5.5分支

源码结构如图:

源码结构.png

  • zookeeper-recipes: 示例源码
  • zookeeper-client: C语言客户端
  • zookeeper-server:主体源码
  1. 刚打开时会发现缺少一大堆的类,根据README.md文件中的说明,我们首先需要先在根目录maven clean + install一次

如果出现类似由于java-doc生成文档失败导致install失败的话,可以将pom.xml文件中的doc项目类插件注释掉重新install

  1. 此时我们所需要的类就会生成到各个项目的target中,但是还是会少一个类org.apache.zookeeper.version.Info
    在包路径下新增类,发布版本时用的,对我们来说没啥用
package org.apache.zookeeper.version;
public interface Info {
    int MAJOR=3;
    int MINOR=5;
    int MICRO=5;
    String QUALIFIER=null;
    int REVISION=-1; //TODO: remove as related to SVN VCS
    String REVISION_HASH="390fe37ea45dee01bf87dc1c042b5e3dcce88653";
    String BUILD_DATE="08/27/2020 03:28 GMT";
}
  1. 打开bin目录下的脚本文件,找到启动类,分别为
  • 客户端:org.apache.zookeeper.ZooKeeperMain
  • 服务端:
  • 单机启动:org.apache.zookeeper.server.ZooKeeperServerMain
  • 集群启动:org.apache.zookeeper.server.quorum.QuorumPeerMain
  1. 此时启动是起不起来的,会报缺少配置文件的错,conf文件下编写配置文件
  • zoo.cfg
tickTime=2000
initLimit=10
syncLimit=5
dataDir=data
clientPort=2181

这里可能会出现找不到类的一些错误,需要将pom文件中相关依赖的scope为provided的改为compile,也可以直接注释,因为默认就是compile

  1. 配置服务启动类的arg参数,Program arguments中填写配置文件的绝对路径,如:D:\zookeeper\conf\zoo.cfg
  2. 启动单机Zookeeper服务端
  3. 接下来尝试启动集群模式的Zookeeper,同样需要编写三份zoo.cfg,并且在数据卷路径下编写myid文件

    集群配置.png
  4. 将配置文件地址配到Program arguments栏中,启动QuorumPeerMain
  5. 启动客户端,客户端默认连接本机2181端口号,在参数栏中指定 server ip:port 可指定连接地址

源码解析

  • 加载配置
  • 开启清理旧日志线程
  • 初始化对外服务(NIO 或 Netty)
  • 初始化会话管理
  • 将日志和快照文件的数据加载到内存中
  • 启动NIO|Netty
  • 开始选举

相关实践学习
基于MSE实现微服务的全链路灰度
通过本场景的实验操作,您将了解并实现在线业务的微服务全链路灰度能力。
目录
相关文章
|
18天前
|
监控 网络协议 Java
Tomcat源码解析】整体架构组成及核心组件
Tomcat,原名Catalina,是一款优雅轻盈的Web服务器,自4.x版本起扩展了JSP、EL等功能,超越了单纯的Servlet容器范畴。Servlet是Sun公司为Java编程Web应用制定的规范,Tomcat作为Servlet容器,负责构建Request与Response对象,并执行业务逻辑。
Tomcat源码解析】整体架构组成及核心组件
|
3天前
|
存储 缓存 Java
什么是线程池?从底层源码入手,深度解析线程池的工作原理
本文从底层源码入手,深度解析ThreadPoolExecutor底层源码,包括其核心字段、内部类和重要方法,另外对Executors工具类下的四种自带线程池源码进行解释。 阅读本文后,可以对线程池的工作原理、七大参数、生命周期、拒绝策略等内容拥有更深入的认识。
什么是线程池?从底层源码入手,深度解析线程池的工作原理
|
3天前
|
设计模式 Java 关系型数据库
【Java笔记+踩坑汇总】Java基础+JavaWeb+SSM+SpringBoot+SpringCloud+瑞吉外卖/谷粒商城/学成在线+设计模式+面试题汇总+性能调优/架构设计+源码解析
本文是“Java学习路线”专栏的导航文章,目标是为Java初学者和初中高级工程师提供一套完整的Java学习路线。
|
7天前
|
开发工具
Flutter-AnimatedWidget组件源码解析
Flutter-AnimatedWidget组件源码解析
|
25天前
|
测试技术 Python
python自动化测试中装饰器@ddt与@data源码深入解析
综上所述,使用 `@ddt`和 `@data`可以大大简化写作测试用例的过程,让我们能专注于测试逻辑的本身,而无需编写重复的测试方法。通过讲解了 `@ddt`和 `@data`源码的关键部分,我们可以更深入地理解其背后的工作原理。
22 1
|
1月前
|
XML Java 数据格式
Spring Cloud全解析:注册中心之zookeeper注册中心
使用ZooKeeper作为Spring Cloud的注册中心无需单独部署服务器,直接利用ZooKeeper服务端功能。项目通过`spring-cloud-starter-zookeeper-discovery`依赖实现服务注册与发现。配置文件指定连接地址,如`localhost:2181`。启动应用后,服务自动注册到ZooKeeper的`/services`路径下,形成临时节点,包含服务实例信息。
127 3
|
1月前
|
开发者 Python
深入解析Python `httpx`源码,探索现代HTTP客户端的秘密!
深入解析Python `httpx`源码,探索现代HTTP客户端的秘密!
66 1
|
1月前
|
开发者 Python
深入解析Python `requests`库源码,揭开HTTP请求的神秘面纱!
深入解析Python `requests`库源码,揭开HTTP请求的神秘面纱!
120 1
|
1月前
|
NoSQL Redis
redis 6源码解析之 ziplist
redis 6源码解析之 ziplist
21 5
|
1月前
|
算法 安全 Java
深入解析Java多线程:源码级别的分析与实践
深入解析Java多线程:源码级别的分析与实践

热门文章

最新文章

推荐镜像

更多