RocketMQ集群No route info of this topic解决方案

在模拟RocketMQ集群故障测试中,遇到producer因服务器故障报'No route info of this topic'异常。分析发现,broker故障导致topic路由信息丢失,而producer不会自动在其他broker上创建topic。解决方法是手动使用mqadmin在所有主broker上预创建topic,确保故障切换时仍能正常服务。经过测试,此方案有效。
摘要由CSDN通过智能技术生成

1.问题描述

    在针对RocketMQ集群做模拟故障测试,测试环境:

         1.两台linux服务器,系统配置MEM:64G,CPU:32 core。RocketMQ版本4.2.0。

         2.每台服务器上部署一个nameSvr,主broker、备broker(两台服务器之间互为主备)

    当在模拟其中一台RocketMQ服务器故障时(强制停止这台服务器所有程序进程),RocketMQ的producer程序出现如下异常:

See http://rocketmq.apache.org/docs/faq/ for further details.
org.apache.rocketmq.client.exception.MQClientException: No route info of this topic, xxx
See http://rocketmq.apache.org/docs/faq/ for further details.
        at org.apache.rocketmq.client.impl.producer.DefaultMQProducerImpl.sendDefaultImpl(DefaultMQProducerImpl.java:564)
        at org.apache.rocketmq.client.impl.producer.DefaultMQProducerImpl.send(DefaultMQProducerImpl.java:1069)
        at org.apache.rocketmq.client.impl.producer.DefaultMQProducerImpl.send(DefaultMQProducerImpl.java:1023)
        at org.apache.rocketmq.client.producer.DefaultMQProducer.send(DefaultMQProducer.java:214)
        at com.cnc.livect.connserver.common.mq.MQProductor.sendDelayMsg(MQProductor.java:144)
        at com.cnc.livect.connserver.common.mq.MQProductor.sendSessionDelayMsg(MQProductor.java:126)
        at com.cnc.livect.connserver.common.session.SessionUtil.start(SessionUtil.java:83)
        at com.cnc.livect.connserver.common.session.SessionUtil.
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值