rabbitmq链接超时_一次奇怪的RabbitMQ超时异常

事情起源于一次本地安装和配置rabbitmq,代码之前是ok的,只是把rabbitmq服务器的ip网段调整到和开发机器不同的网段后(备注,有设置两者互通,并且防火墙也是通的);

但是当做完rabbitmq服务器的网段后,开发机器的代码就访问rabbitmq,就报错connection error or timeout。

1. 环境介绍

rabbitmq 服务器:192.168.13.21

开发机器:192.168.3.6

两者网络是联通的,并且rabbitmq服务器的防火墙是允许客户端ip访问端口5672( amqp)和15672(http web)

cmd >> ping 192.168.13.21

95c5769f886d0ea1de45e111e875704a.png

cmd >> telnet 192.168.13.21 5672

b02538bd211f8db273e5ba84f3ca7277.png

2. old 代码,原有的timeout,分别设置如下

eab680847819551c3da52c0f35b80d18.png

启动程序报错,如下:

5c01b0b9f44339382d586d7ef641b043.png

3. new 代码,修改的timeout,分别设置如下:同时必须增加sethandshaketimeout参数

f5f32cd4453c2ed573a8c182594dfede.png

连接和执行成功,如下:

371b15c3490795c24320dd2c7e0439e0.png

4.解决办法:

最后,发现根本原因,可能是本地开发机器和rabbitmq服务器之间,不同网段的地址或ip解析产生过多耗时。

原因:本地开发机器的网卡设置,我是通过增加一个ip="192.168.13.6",来实现本地开发机器和“rabbitmq服务器”之间不同网段的互相通讯。

55b6582311078cd08ebc2c27cb892072.png

step 1: 修改rabbitmq服务器的host文件,告诉rabbbitmq服务器,他自己的ip和hostname

root >> vi /etc/host

# 增加如下参数

de4f35b0450f749ba8e856d16c58e261.png

然后,重启一下rabbitmq

root >> systemctl restart rabbitmq-server

739cac5a1604df1be5fa40c8c2d0336f.png

step 2: 重新在开发机器上,测试之前的old代码

# 测试之前的old代码,timeout设置还是60ms,没有添加参数sethandshaketimeout。

# 但是,这次连接和发送rabbitmq成功

09709d41689aec55efb018cffa8170be.png

希望与广大网友互动??

点此进行留言吧!

  • 2
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值