ZooKeeper 启动过程分析
来源:互联网 发布:网络黄金egd上市 编辑:程序博客网 时间:2024/04/29 14:40
单机服务器启动
ZooKeeper服务器启动,大体分为五个主要步骤:配置文件解析、初始化数据管理器、初始化网络I/O管理器、数据恢复和对外服务。
预启动
预启动的步骤如下:
1、统一由QuorumPeerMain作为启动类2、解析配置文件zoo.cfg3、创建并启动历史文件清理器DatadirCleanupManager4、判断当前是集群模式还是单机模式的启动5、再次进行配置文件zoo.cfg的解析6、创建服务器实例ZooKeeperServer
初始化
1、创建服务器统计器ServerStats2、创建ZooKeeper数据管理器FileTxnSnapLog3、设置服务器tickTime和会话超时时间限制4、创建ServerCnxnFactory5、初始化ServerCnxnFactory6、启动ServerCnxnFactory主线程7、恢复本地数据8、创建并启动会话管理器9、初始化ZooKeeper的请求处理链10、注册JMX服务11、注册ZooKeeper服务器实例
集群服务器启动
预启动
预启动步骤如下:
1、统一由QuorumPeerMain作为启动类2、解析配置文件zoo.cfg3、创建并启动历史文件清理器DatadirCleanupManager4、判断当前是集群模式还是单机模式的启动
初始化
初始化步骤如下:
1、创建ServerCnxnFactory2、初始化ServerCnxnFactory3、创建ZooKeeper数据管理器FileTxnSnapLog4、创建QuorumPeer实例5、创建内存数据库ZKDatabase6、初始化QuorumPeer7、恢复本地数据8、启动ServerCnxnFactory主线程
Leader选举
Leader选举的步骤如下:
1、初始化Leader选举2、注册JMX服务3、检测当前服务器状态4、Leader选举
Leader和Follower启动期交互过程
Leader和Follower服务器启动期交互过程包括如下步骤
1、创建Leader服务器和Follower服务器2、Leader服务器启动Follower接收器LearnerCnxAcceptor3、Learner服务器开始和Leader建立连接4、Leader服务器创建LearnerHandler5、向Leader注册6、Leader解析Learner信息,计算新的epoch7、发送Leader状态8、Leaner发送ACK消息9、数据同步10、启动Leader和Learner服务器
Leader和Follower启动
Leader和Follower启动步骤如下:
1、创建并启动会话管理器2、初始化ZooKeeper的请求处理链3、注册JMX服务
更多精彩内容,欢迎关注微信公众号:Java小笔记(ijavanote)
0 0
- ZooKeeper 启动过程分析
- zookeeper启动选举过程分析
- zookeeper源码分析之一启动过程
- Zookeeper-Zookeeper启动过程
- Zookeeper-Zookeeper启动过程
- Zookeeper-Zookeeper启动过程
- Zookeeper-Zookeeper启动过程
- Zookeeper源码分析(一)-Zookeeper启动过程
- Zookeeper(4)-Zookeeper启动过程
- ZooKeeper启动过程
- Zookeeper启动过程
- Zookeeper启动过程
- zookeeper-启动过程
- zookeeper服务器启动过程
- Zookeeper启动过程
- Zookeeper 3.3.3 启动过程
- ZooKeeper启动过程2:FastLeaderElection
- zookeeper启动过程函数调用
- Django下实现HelloWorld
- MATLAB 如何输出-print,fprint,fscanf,disp
- libevent 之 hello world
- 328. Odd Even Linked List
- 超级厉害的JavaScript —— ECMAScript 6 标准(8) —— Promise对象
- ZooKeeper 启动过程分析
- Qt creator5.7 OpenCV249之resize函数(含源码下载)
- java并发编程(十一)----(JUC原子类)基本类型介绍
- 哈理工OJ 2255 镇守府海域·镇守府近海(模拟题目)
- javascript基础 悬停字体变大离开变小
- C语言 gets()和scanf()函数的区别
- C++基础学习之13 - 可视化设计
- AttributeError: 'dict' object has no attribute 'iteritems'
- day_02