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

本文详细介绍了Zookeeper中Listener、ListenerHandler、SendWorker和RecvWorker的数据结构以及它们在选举过程中的作用,包括Listener负责管理服务器端口,ListenerHandler监听连接请求,SendWorker负责发送选举信息,RecvWorker接收消息。
摘要由CSDN通过智能技术生成

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选举期间的网络通信到此为止。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值