问题记录
超时问题出现的原因可能有两种
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 &