异常原因
1. Broker禁止自动创建Topic,且用户没有通过手工方式创建Topic
2. Broker没有正确连接到Name Server
3. Producer没有正确连接到Name Server
解决与验证方法
解决问题1:
启动顺序要先启动nameserver,再启动broker,启动broker时加上autoCreateTopicEnable=true例如 nohup sh mqbroker -n localhost:9876 autoCreateTopicEnable=true &
解决问题2:
启动没有异常检查下nameserver中是否成功注册了broker,有两种方式
第一种、看broker的日志 如果出现形如
2018-02-28 16:21:35 INFO BrokerControllerScheduledThread1 - register broker to name server 192.168.192.129:9876 OK
2018-02-28 16:22:05 INFO BrokerControllerScheduledThread1 - register broker to name server 192.168.192.129:9876 OK
证明已经连接到nameserver上
第二种、 在bin目录下执行命令sh mqadmin clusterList -n localhost:9876 如果看到
#Cluster Name #Broker Name #BID #Addr #Version #InTPS(LOAD) #OutTPS(LOAD) #PCWait(ms) #Hour #SPACE
DefaultCluster DEFAULT_BROKER 0 192.168.192.129:10911 V4_2_0_SNAPSHOT 0.00(0,0ms) 0.00(0,0ms) 0 422168.55 -1.0000
也是证明已经连接到nameserver上。