RocketMQ 关于 No route info of this topic 问题

rocketmq访问时出现 No route info of this topic 异常产生的原因:

  1. Broker禁止自动创建Topic,且用户没有通过手工方式创建Topic
  2. Broker没有正确连接到Name Server
  3. Producer没有正确连接到Name Server (防火墙问题)

第一种情况解决方法

先将已有服务关闭

# 1.关闭Nameserver
sh bin/mqshutdown namesrv
# 2.关闭Broker
sh bin/mqshutdown broker

然后顺序启动nameserver

# 1.启动nameserver
nohup sh bin/mqnamesrv &
# 2.查看启动日志
tail -f ~/logs/rocketmqlogs/namesrv.log

再启动broker,启动broker的时候可以进行手动或者自动添加topic

  • 自动:启动broker时加上autoCreateTopicEnable=true
nohup sh mqbroker -n localhost:9876 autoCreateTopicEnable=true &

启动没有异常的情况下,检查下nameserver中是否成功注册了broker
查看broker日志内容:
RocketMQ 关于 No route info of this topic 问题_第1张图片

  • 手动:正常启动broker,再执行创建
# 1.启动Broker
nohup sh bin/mqbroker -n localhost:9876 &
# 2.查看启动日志
tail -f ~/logs/rocketmqlogs/broker.log

# 先查看有没有topic
sh bin/mqadmin topicList -n localhost:9876
# 或者查看详情
sh bin/mqadmin topicstatus -n localhost:9876 -t test_topic
* test_topic是topic名称

# 手动新增topic
sh mqadmin updateTopic -n localhost:9876  -b localhost:10911  -t test_topic	
* 加完后记得查看一下是否加成功了

第二种情况解决方法

查看是否连接正确,执行命令

sh bin/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.1.128:10911    V4_5_1          0.00(0,0ms)        0.00(0,0ms)          0 1847.32 0.5485

否则就是broker或者namesrv启动有问题,大部分都是brokerIP1=192.168.1.128 没有配置正确。需要去conf/broker.conf修改一下brokerIP1,然后再走一遍正常启动流程就可以了

第三种情况解决方法

如果是防火墙的原因 ,需要关闭防火墙,命令为

# 停止防火墙
systemctl stop firewalld.service
# 禁用防火墙
systemctl disable firewalld.service
* 禁用会使得下次开机不会自启

其它:
RocketMQ默认的虚拟机内存较大,启动Broker如果因为内存不足失败,需要编辑如下两个配置文件,修改JVM内存大小

# 查看服务内存情况
free -h
# 编辑runbroker.sh和runserver.sh 修改默认JVM大小
vi runbroker.sh
vi runserver.sh

你可能感兴趣的:(中间件,中间件)