RocketMQ消息发送失败--RemotingTooMuchRequestException: sendDefaultImpl call timeout

问题记录

在这里插入图片描述
超时问题出现的原因可能有两种
1. 客户端连接失败
请仔细检查服务器域名及端口,并保证rocketmq启动在当前端口,且端口可以被外部正常访问.
2. 消息等待超时
rocketmq生产者同步发送消息默认的超时等待时间为3s,有可能因为各种原因超过3000ms就会抛出上述错误,因此可以尝试将超时时间调大(例如6000ms).

问题解决

1. 查看服务器防火墙是否关闭

 # 查看防火墙状态
 systemctl status firewalld
 # 关闭防火墙
 systemctl stop firewalld

2. 修改配置文件

我们需要修改rocketmq的安装目录下的conf/broker.conf文件,在文件后追加如下内容

brokerIP1=服务器ip地址
nameSrvAddr=服务器IP地址:端口号

3. 查看对应端口是否开启

我使用的是华为云服务器,需要登录华为云控制台,将对应端口加入安全组,确保对外能顺利访问.同时请注意需要打开的端口不止有指定的端口(默认9876),还需要打开10911和10909,否则会出现上述错误其中10909端口为vip通道,如不使用该通道,可以不打开该端口,但需要在代码中设置关闭vip通道.

producer.setVipChannelEnabled(false);

4. 设置超时等待时间

rocketmq生产者同步发送消息默认的超时等待时间为3s,有可能因为各种原因超过3000ms就会抛出上述错误,因此可以尝试将超时时间调大(例如6000ms).

producer.setSendMsgTimeout(6000);

5. broker启动时指定配置文件启动

nohup sh bin/mqbroker -n 服务器ip:端口 -c ./conf/broker.conf &
  • 1
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值