Loading

org.apache.rocketmq.client.exception.MQClientException: No route info of this topic异常解决

No route info of this topic异常

使用RocketMQ发送消息抛出异常,异常如下:

上述异常报错的是找不到主题路由信息;

 

报错原因一般如下

  • 如果NameServer中不存在该主题的路由信息,并且没有开启自动创建主题,则抛出 No route info of this topic的异常;
  • 如果开启了自动创建主题,则使用默认主题向NameServer查询路由信息,并使用默认主题的路由信息作为自己的路由信息,则不会抛出No route info of this topic的异常;

 

异常排查

排查如下:

  • 可通过rocketmq-console查询路由信息是否存在,或使用如下命令查询路由信息,如下:
sh mqadmin topicRoute -n 127.0.0.1::9876 -t [需要查询的topic]

  • 如果通过命令无法查询到路由信息,则通过autoCreateTopicEnable查看Broker是否开启了自动创建主题,但在生产环境中不建议开启自动创建主题;

1. 修改broker.properties配置,自动创建topic,添加如下:

autoCreateTopicEnable= true

  

2. 升级RocketMQ版本为4.4.0+,新版本会默认自动创建

<dependency>
    <groupId>org.apache.rocketmq< /groupId >
    <artifactId>rocketmq-client< /artifactId >
    <version>4.4.0< /version >
< /dependency >

  

  • 如果开启了自动创建主题,但还是抛出这个错误,就需要检查Producer连接的NameServer地址是否与Broker中配置的NameServer地址是否一致;
posted @ 2019-12-29 16:14  街头卖艺的肖邦  阅读(22191)  评论(0编辑  收藏  举报