《Zookeeper》源码分析(十一)之选举通信网络辅助类

目录

Listener

Listener用于管理服务器的选举端口。

数据结构

构造函数

run()

Listener的主要工作是创建一系列的ListenerHandler并将他们投放到线程池中等待执行,在第1步中如果想要开启多个地址:

  1. 启动的时候添加java参数-Dzookeeper.multiAddress.enabled=true
  2. 在配置文件的服务器地址添加多个端口,如server.1=localhost:2888:3888|localhost:2891:3891

如果按照这个配置,那么服务器会开启3888和3891两个端口用于选举。

ListenerHandler

数据结构

run()

ListenerHandler的工作主要是监听来自对方服务器的连接请求,一旦监听到连接请求则转交给QuorumCnxManager处理。

SendWorker

两个服务器之间一旦建立连接,就会根据sid创建一个对应的SendWorker,用于后续的选举信息发送。

数据结构

构造函数

run()

SendWorker 的工作是从QuorumCnxManager.queueSendMap队列中获取待发送的信息发送给目标服务器。

RecvWorker

RecvWorker不断地从TCP连接中读取消息并存放到QuorumCnxManager.recvQueue中。

数据结构

run()

至此,关于zookeeper选举期间的网络通信到此为止。

相关推荐
灰色孤星A1 天前
Kafka学习笔记(三)Kafka分区和副本机制、自定义分区、消费者指定分区
zookeeper·kafka·kafka分区机制·kafka副本机制·kafka自定义分区
漫无目的行走的月亮3 天前
Ubuntu下安装Zookeeper集群
linux·ubuntu·zookeeper
程序那点事儿4 天前
zookeeper 服务搭建(集群)
linux·分布式·zookeeper
楼下创了电瓶车5 天前
ubuntu20.04系统安装zookeeper简单教程
分布式·zookeeper·云原生
AAA 建材批发王哥(天道酬勤)5 天前
ZooKeeper
java·zookeeper
lzhlizihang5 天前
Hadoop集群的高可用(HA):NameNode和resourcemanager高可用的搭建
hadoop·zookeeper·高可用·ha
懒鸟一枚6 天前
Zookeeper下载、安装配置
分布式·zookeeper
程序那点事儿7 天前
zookeeper 服务搭建(单机)
分布式·zookeeper·云原生·java-zookeeper
花千树-0108 天前
深度对比:etcd、Consul、Zookeeper 和 Nacos 作为注册中心和配置中心的优势与劣势
微服务·zookeeper·服务发现·etcd·consul
花千树-0108 天前
Dubbo 如何使用 Zookeeper 作为注册中心:原理、优势与实现详解
分布式·zookeeper·dubbo