NameServer

概述

Name server主要负责对于源数据的管理,包括了对于Topic和路由信息的管理,Broker在启动的时候会去向Name server注册并且定时发送心跳,Producer在启动的时候会到Name server上去拉取Topic所属的broker具体地址,然后向具体的broker发送消息。

特点

  1. Name Server是一个几乎无状态的结点,Name Server之间采取share-nothing的设计,互不通信。

  2. 对于一个Name Server集群列表,客户端连接Name Server的时候,只会选择随机连接一个结点,以做到负载均衡。

  3. Name Server所有状态都从Broker上报而来,本身不存储任何状态,所有数据均在内存。

  4. 如果中途所有Name Server全都挂了,影响到路由信息的更新,不会影响和Broker的通信。

源码阅读

核心类

  • NamesrvStartUp:启动类

  • NamesrvController:管理类,控制NameServer的生命周期

  • RouteInfoManager:路由信息管理类,管理topic队列信息、broker地址信息、集群信息等

  • DefaultRequestProcessosr:请求处理类,处理网络请求,broker注册

数据结构

NamesrvStartup

NamesrvController

DefaultRequestProcessosr

RouteInfoManager

Last updated