RocketMQ版本:4.4.0-release
报错信息:在发送异步消息时出现以下异常
解决方案(前三种是其他帖子广泛流传的):
1.Broker模块不支持自动创建topic,并且topic没有被手动创建过
实际上,这种情况出现的机率很小,因为在较新版rocketMQ中,autoCreateTopicEnable默认值为true,会自动创建topic
2.Broker模块没有正确连接到NAMESRV
第二种情况出现的概率较低,可以采用以下两种方式确认
1. 查看broker的日志,出现如下内容,说明连接成功。
查看日志命令 cat ~/logs/rocketmqlogs/broker.log | grep register
2019-12-04 09:40:16 INFO brokerOutApi_thread_1 - register broker to name server localhost:9876 OK 2019-12-04 09:40:46 INFO brokerOutApi_thread_2 - register broker to name server localhost:9876 OK
2. 在mq的安装目录执行如下命令
sh mqadmin clusterList -n localhost:9876
出现如下内容说明连接成功,没有问题
3.发送者没有连接到NAMESRV
第三种情况出现的最大可能是发送者和mq服务器之间的网络或端口不通,可以使用ping或者telnet确定问题。如果ping或者telnet连接不通,需要联系运维工程师开通网络或端口权限。
4.生产者提前被关闭
因为发送的是异步消息,所以存在异步消息还未得到响应前producer就被关闭的情况,遇到这种情况也会抛出这样的异常,最简单的解决方法是在producer关闭前让线程暂停几秒: