## nameServer职责
管理主题、队列、broker等信息,给生产者发送消息以及消费者消费消息提供了路由功能,找到对应的broker。
## 设计思路
1. broker通过心跳注册到集群中的所有nameServer中,每个nameServer保留了同一份数据。
2. 使用多个HashMap保存路由信息,使用一个ReadWriteLock控制并发。
3. 使用定时任务清除心跳过期的broker信息,所以从nameServer获取到的数据不是最新的,有一定延时。
## 学习总结
1. 代码中使用NamesrvController类作为门面类。
2. 代码中抽离了remote模块,对底层通信统一封装,外部模块引用时设置自定义的processer,来处理RemotingCommand请求。



