1. NameServer到底可以部署几台机器
要部署RocketMQ,就得先部署NameServer,那么NameServer到底可以部署几台机器呢?是一台机器还是可以部署多台机器,如果部署多台机器,他们之间是怎么协同工作的?
NameServer是支持部署多台机器的,也就是可以集群化部署,最主要的原因就是为了高可用性。因为NameServer是集群里面非常关键的一个角色,他要管理Broker的信息,别人都要通过他才知道要跟哪个Broker通信,所以没了他就会很麻烦。
那么如果NameServer就部署一台机器,一旦NameServer宕机了,就会导致整个RocketMQ集群出现故障;所以通常来说,NameServer一定会多机器部署,实现一个集群,起到高可用的效果,保证任何一台机器宕机,其他机器上的NameServer可以继续对外提供服务。
2. Broker是把自己的信息注册到哪个NameServer上?
有人可能会猜测,是不是这样,比如一共有10台Broker机器,2个NameServer机器,然后其中5台Broker会把自己的信息注册到1个NameServer上,另外5台Broker把自己的信息注册到另外一个NameServer上去?
答案是不对的,这样搞有一个最大的问题,如果1台NameServer上有5个Broker的信息,另外一个NameServer上有另外5个Broker的信息,那么此时任何一个NameServer宕机了,不就导致5个Broker的信息就没了吗?
所以