RocketMQ Demo 启动报错 No route info of this topic

com.alibaba.rocketmq.client.exception.MQClientException: No route info of this topic, TopicTest1
See http://docs.aliyun.com/cn#/pub/ons/faq/exceptions&topic_not_exist for further details.
at com.alibaba.rocketmq.client.impl.producer.DefaultMQProducerImpl.sendDefaultImpl(DefaultMQProducerImpl.java:542)
at com.alibaba.rocketmq.client.impl.producer.DefaultMQProducerImpl.send(DefaultMQProducerImpl.java:1030)
at com.alibaba.rocketmq.client.impl.producer.DefaultMQProducerImpl.send(DefaultMQProducerImpl.java:989)
at com.alibaba.rocketmq.client.producer.DefaultMQProducer.send(DefaultMQProducer.java:90)
at com.yang.rocketmq.Producer.main(Producer.java:45)
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:57)
at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
at java.lang.reflect.Method.invoke(Method.java:606)
at com.intellij.rt.execution.application.AppMain.main(AppMain.java:147)


按照官方文档启动broker
↓↓↓↓↓↓这是错误的!!!↓↓↓↓↓↓

nohup sh bin/mqbroker -n localhost:9876 &

↑↑↑↑↑↑这是错误的!!!↑↑↑↑↑↑


改为:
↓↓↓↓↓↓这才是正确的!!!↓↓↓↓↓↓

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

↑↑↑↑↑↑这才是正确的!!!↑↑↑↑↑↑


参考资料:

1、RocketMQ报错No route info of this topic解决方案
https://blog.csdn.net/yangding_/article/details/62419383

### 解决 RocketMQ 中 "No route info of this topic" 错误 当遇到 `org.apache.rocketmq.client.exception.MQClientException: No route info of this topic` 这类错误时,通常意味着客户端无法获取指定主题的路由信息。这可能是由于多种原因引起的。 #### 可能的原因分析 1. **Broker未成功连接至Name Server** 如果 Broker 没有成功注册到 Name Server,则 Producer 和 Consumer 将无法找到 Topic 的路由信息[^2]。 2. **Topic尚未创建或配置不正确** 若 Topic 并不存在于集群中或者其配置存在问题,也会导致此异常发生[^3]。 3. **网络通信问题** 不稳定的网络环境可能导致消息队列之间的通讯失败,进而影响正常的路由查找过程[^1]。 #### 解决策略 为了有效解决问题并确保系统的稳定运行: - **确认服务状态** 验证 NameServer 是否已启动并且处于正常工作状态;通过命令行工具检查 Broker 实例是否能够顺利连通 NameServer,并且已经向后者完成了必要的注册流程。 - **验证Topic的存在性和权限设置** 使用管理界面或其他方式确认目标 Topic 已经被正确建立,并赋予了相应的读写访问控制列表 (ACL) 权限给当前的应用程序实例。 - **调整应用程序逻辑** 对于新发布的应用版本,在发送第一条消息之前先调用一次 MQAdmin 提供的相关 API 方法来显式创建所需的 Topics 或者等待一段时间让系统自动完成初始化动作。 - **优化日志记录机制** 增强现有代码中的异常处理部分,增加更多上下文信息的日志输出以便后续排查潜在隐患所在之处。 ```python from rocketmq.client import PushConsumer, MessageSelector consumer = PushConsumer('your_group_name') try: consumer.start() except Exception as e: logger.error(f"Failed to start consumer with error {str(e)}") finally: # Ensure resources are released properly even when exceptions occur. consumer.shutdown() def check_and_create_topic(admin_client, topic_name): try: admin_client.create_or_update_topic(topic_name=topic_name) print("Successfully ensured the existence of", topic_name) except Exception as ex: print("Error occurred while ensuring topic:", str(ex)) ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值