RocketMQ 解决 No route info of this topic

rocketmq运行时提示 No route info of this topic 异常产生的原因可能是①Broker禁止自动创建Topic,且用户没有通过手工方式创建Topic②Broker没有正确连接到Name Server③Producer没有正确连接到Name Server首先解决①这种情况,启动顺序要先启动nameserver,再启动broker,启动broker时加上autoC...
摘要由CSDN通过智能技术生成

rocketmq运行时提示 No route info of this topic 异常产生的原因可能是

①Broker禁止自动创建Topic,且用户没有通过手工方式创建Topic

②Broker没有正确连接到Name Server
③Producer没有正确连接到Name Server

首先解决①这种情况,启动顺序要先启动nameserver,再启动broker,启动broker时加上autoCreateTopicEnable=true

例如 nohup sh mqbroker -n localhost:9876 autoCreateTopicEnable=true &

启动没有异常检查下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上。

如果按前两步检查没有问题,但启动还是报错,那么剩下的可能原因是producer无法连接到nameserver,很可能是防火墙的原因 ,要检验猜测只需要关闭防火墙,命令为systemctl stop firewalld.service
然后再次验证,应该已经可以使用了。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
MQClientException: No route info of this topicRocketMQ客户端的一个异常,表示在指定的主题上没有找到路由信息。这通常是由于以下原因之一引起的: 1. 主题不存在:确保你在RocketMQ中创建了名为"topic-1"的主题。你可以使用RocketMQ的管理工具或命令行工具来创建主题。 2. 主题路由信息未更新:如果你在创建主题之后立即使用它,可能会出现这个异常。在RocketMQ中,主题的路由信息需要一些时间来更新和分发到所有的Broker节点。请等待一段时间后再尝试使用主题。 3. 客户端配置错误:检查你的客户端配置,确保你正确指定了正确的NameServer地址和主题名称。确保你的客户端代码中没有拼写错误或其他语法错误。 解决这个问题的方法是: 1. 确保主题存在并且已正确创建。 2. 等待一段时间,以确保主题的路由信息已更新。 3. 检查你的客户端配置,确保你正确指定了正确的NameServer地址和主题名称。 4. 检查你的客户端代码,确保没有拼写错误或其他语法错误。 5. 如果问题仍然存在,尝试重新启动RocketMQ服务和你的应用程序。 ```java import org.apache.rocketmq.client.exception.MQClientException; import org.apache.rocketmq.client.producer.DefaultMQProducer; import org.apache.rocketmq.common.message.Message; public class Producer { public static void main(String[] args) throws MQClientException { DefaultMQProducer producer = new DefaultMQProducer("producer_group"); producer.setNamesrvAddr("localhost:9876"); producer.start(); try { Message message = new Message("topic-1", "Hello RocketMQ".getBytes()); producer.send(message); System.out.println("Message sent successfully."); } catch (Exception e) { e.printStackTrace(); } producer.shutdown(); } } ```

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值