总结一下最近rocketMQ踩过的坑,以及它的一个解决办法汇总。

1.解决RocketMQ报No route info of this topic:异常

近日在做RocketMQ的时候,mqnamesrv和mqbroker都正常启动了,但是在运行生产者的时候,报了个No route info of this topic的异常,让我很是郁闷。上网找了一些资料,现把解决办法记录如下,如果还有其他的原因导致这个问题的,后续会补充。

解决方法一:

Linux系统下:

在启动mqbroker的时候需要指定 autoCreateTopicEnable=true。例如:

nohup sh mqbroker -n 192.168.180.133:9876
autoCreateTopicEnable=true > ~/logs/rocketmqlogs/broker.log 2>&1 &

window系统下:

在window系统下需要在cmd中启动mqbroker才行。命令格式如下:
mqbroker.exe -n localhost:9876autoCreateTopicEnable=true

有网友在下面评论说缺少fastjson jar包也会导致此问题。

解决方法二:

可能是没有关闭防火墙。
原因2 转自:https://blog.csdn.net/chenaima1314/article/details/79403113

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
然后再次验证,应该已经可以使用了。

2.关于RocketMQ消息收不到的问题

可能是由于 VIP 端口无法连接,从而导致消费端无法正常消费消息。
详情请见::https://www.cnblogs.com/goodAndyxublog/p/14028403.html

3.mqnameserver 或者 mqbroker 没有启动成功。

要在 /distribution/target/apache-rocketmq/bin 下的2个脚本中设置内存占用大小。

vim bin/runserver.sh (调整nameserver启动的内存,不调整此文件,可能导致无法启动。)
 
JAVA_OPT="${JAVA_OPT} -server -Xms256m -Xmx256m -Xmn512m -XX:MetaspaceSize=128m -XX:MaxMetaspaceSize=320m" 
 
 vim bin/runbroker.sh     JAVA_OPT="${JAVA_OPT} -server -Xms256m -Xmx256m -Xmn128m"

4.把内网ip改成公网ip

解决方案:
1.修改broker.conf,内容如下:

brokerClusterName = DefaultCluster
brokerName = broker-a
brokerId = 0
deleteWhen = 04
fileReservedTime = 48
brokerRole = ASYNC_MASTER
flushDiskType = ASYNC_FLUSH
namesrvAddr=47.101.167.214:9876
listenPort=10911
brokerIP1=47.101.167.214

这里的47.101.167.214是公网IP

2. 启动Name Server:

nohup sh bin/mqnamesrv &

3. 启动Broker:

nohup sh bin/mqbroker -n 47.101.167.214:9876 -c conf/broker.conf &

=======

定位问题的过程:

在GitHub上找到了相同问题: https://github.com/apache/rocketmq/issues/568 ,里面说要么设置setVipChannelEnabled,要么开放10911、10909这两个端口。

而测试代码使用的是RocketMQTemplate玩的,无法直接操作setVipChannelEnabled,所以不妨顺着第二条路走(开放10911、10909这两个端口)

然而,我发现在本机telnet 10911、10909这两个端口是通的,说明端口开放没问题。

====

陷入僵局后,我就分析nohup日志,发现有类似如下的日志:

The broker[iZuf6h6yzsw5uybsq1y7w8Z, 172.19.172.31:10911] boot success. serializeType=JSON and name server is 47.101.167.214:9876

也就是说,broker启动时,往Name Server注册的是个内网地址(172.19.172.31),而我们希望是公网地址。所以,修改下broker.conf,设置下IP;并在启动broker时,用-c conf/broker.conf 指定读取配置文件。

此时,会打印类似如下的日志,和预期相符。

The broker[broker-a, 47.101.167.214:10911] boot success. serializeType=JSON and name server is 47.101.167.214:9876

=====

注意点:

需要开放10911、10909这两个端口

需修改broker.conf,设置公网IP

启动broker时,需用-c conf/broker.conf,读取配置文件

其他参考:

https://www.jianshu.com/p/ca3a87bed2c2

http://www.bijishequ.com/detail/532581

http://blog.csdn.net/c_yang13/article/details/76836753

  • 2
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 6
    评论
在分布式事务中使用RocketMQ时,可能会遇到一些。其中一个主要的是如何保证分布式事务的正确执行。有几种常用的分布式事务解决方案,包括XA方案(两阶段提交方案)、TCC方案(try、confirm、cancel)、SAGA方案、可靠消息最终一致性方案和最大努力通知方案。 在RocketMQ中,主要采用了可靠消息最终一致性方案来实现分布式事务。这个方案的主要思路是,在发送消息时,将消息和事务绑定,然后将消息先存储在Broker节点上,等到事务提交成功后再真正发送消息。如果事务提交失败,就会回滚消息,保证消息的一致性。这个方案相对来说较为简单,但是需要保证消息的可靠性和幂等性。 当然,在使用RocketMQ时,也需要考虑具体的业务需求、时间、成本以及开发团队的实力。分布式还有很多其他的,具体要根据情况来决定是否使用分布式架构。 希望以上信息对您有所帮助。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *3* [这三年被分布式惨了,曝光十大](https://blog.csdn.net/jackson0714/article/details/108775573)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] - *2* [RocketMQ事务消息学习及刨过程](https://blog.csdn.net/huangying2124/article/details/102634761)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值