Nameserver的主要作用是为消息的生产者和消息消费者提供关于主题Topic的路由信息,那么Nameserver需要存储路由的基础信息,还要管理Broker节点,包括路由注册、路由删除等。
一、路由元数据
路由元数据主要保存了topic信息,broker信息等
代码:RoutelnfoManager
我们先看下RoutelnfoManager中的五个map,分别存储了哪些元数据。
private final HashMap<String/* topic */, Map<String /* brokerName */ , QueueData>> topicQueueTable;
private final HashMap<String/* brokerName */, BrokerData> brokerAddrTable;
private final HashMap<String/* clusterName */, Set<String/* brokerName */>> clusterAddrTable;
private final HashMap<String/* brokerAddr */, BrokerLiveInfo> brokerLiveTable;
private final HashMap<String/* brokerAddr */, List<String>/* Filter Server */> filterServerTable;
topicQueueTable:**Topig消息队列路由信息,消息发送时根据路由表进行负载均衡brokerAddrTable:Broker基础信息,包括brokerName、所属集群名称、主备Broker地