【已解决】RocketMQ在发送消息的时候,提示:MQClientException: No route info of this topic

  • 作者: 凯哥Java(公众号:凯哥Java)
  • RocketMQ
  • 时间:2022-10-18 17:42
  • 5200人已阅读
简介 RocketMQ在发送消息的时候,提示:MQClientException: No route info of this topic xxx

🔔🔔好消息!好消息!🔔🔔

 如果您需要注册ChatGPT,想要升级ChatGPT4。凯哥可以代注册ChatGPT账号代升级ChatGPT4

有需要的朋友👉:微信号 kaigejava2022

RocketMQ在发送消息的时候,提示:MQClientException: No route info of this topic xxx

5846d1ba3a6be8b26b564e9e87b3bac4.png错误提示是说,没有xxx这个topic.

出现topic不存在,主要有以下三种情况导致的:

第一种:broker中真的没有xxx这个topic.

可能原因:Broker模块不支持自动创建topic,并且xxxtopic也没有被手动创建多

第二种:borker模块没有正确连接到NAMESRV

第三种:发送者没有连接到NAMESRV

知道了产生原因,我们就来解决办法:

第一种情况查看topic是否正的存在。可以登录rockermq控制台查看:

f14cdad81c3a90b49fc260d0ef5c4612.png

可以搜索topic。

或者查看broker的日志确定topic是否真的存在。

登录MQ所在的服务器机器上,执行如下命令(注意:把recommend换成你自己的topic名称)

cat ~/logs/rocketmqlogs/broker.log  | grep topicName=recommend

出现如下内容说明topic已经存在:

3fbdb3d16311949ed13b56cc2b7d05ab.png如果没有出现以上内容,说明topic确实不存在。可以通过自动创建topic或者手动创建topic解决问题。

自动创建topic:可以在启动broker启动脚本添加自动创建topic参数。或者在启动时候指定broker.conf配置文件中添加:

autoCreateTopicEnable=true

表示自动创建topic.

或者手动创建topic。

手动创建topic的话,可以直接在控制台创建。凯哥就不演示了。

第二种情况出现的概率极低。可以采用以下两种方式确认

1. 查看broker的日志,出现如下内容,说明连接成功。

查看日志命令 cat ~/logs/rocketmqlogs/broker.log | grep register

2. 在mq的安装目录执行如下命令

mqadmin clusterList -n localhost:9876

出现如下内容说明连接成功,没有问题

1e7da6870dc99be7552674cf9fc6446a.png

第三种情况出现的最大可能是发送者和mq服务器之间的网络或端口不通,可以使用ping或者telnet确定问题。如果ping或者telnet连接不通,需要联系运维工程师开通网络或端口权限

凯哥遇到的是第一种情况,topic确实不存在,是通过手动创建topic解决的


TopTop