admin管理员组文章数量:1608632
使用Nacos遇到ioty.channel.AbstractChannel$AnnotatedConnectException: Connection timed out: no further information: /xxxx:xx
- 遇到的问题
- 过程
- 总结
- 扩展
遇到的问题
上图片
过程
研究半天发现nacos配置没问题,服务也没问题,最后发现是注册的ip是 VMware Network Adapter VMnet8,然后ping了一下这个虚拟ip发现不通,但是VMware Network Adapter VMnet1可以通,于是我先下掉了V8
下掉V8之后果然登录成功了,但是openFeign调用服务又不通了message:feign.RetryableException: connect timed out executing POST,但是openFeign也没问题,我心想是不是还是虚拟网卡的问题,于是我把V1也关掉了,最后确实通了
总结
原来Nacos客户端在注册服务时会从机器网卡中选择一个IP来注册,当机器存在多个网卡(例如存在虚拟网卡)时,所选则的IP可能不是真是的物理机的IP,所以,当注册了的是非真实IP后,另一台机器调用时是不可能调通的。
知道问题后,就要解决,查了一下SpringCloud的官方文档,发现有一项配置如下:
spring:
cloud:
inetutils:
preferredNetworks:
- xxx.xxx.xxx.xxx
该项配置用于指定首选IP,当有多个网卡时,指定该IP地址后(支持正则),客户端在选择IP时就会选择符合preferredNetworks配置的IP地址进行注册。
同样的,Nacos也可以配置自己的首选IP以及网卡选择:
spring.cloud.nacos.discovery.ip:
spring.cloud.nacos.discoveryworkInterface
扩展
虽然问题解决了,但是还是要更深入的了解一下这个IP选择的逻辑。翻了一通源码发现,其大致逻辑如下:
Nacos首先检查有没有ip及networkInterface配置,如果有则使用配置的IP,否则检查networkInterface,并获取IP,如果两者都为空,则使用inetUtils.findFirstNonLoopbackHostInfo().getIpAddress()来获取IP,它最终会返回一个匹配的IPV4地址,并且排除本机回环网络(127.0.0.0-127.255.255.255),并且匹配是否是首选网络(如果配置了preferredNetworks)。
本文标签: NettyChannelNacosIOAbstractChannel
版权声明:本文标题:使用Nacos遇到io.netty.channel.AbstractChannel$AnnotatedConnectException: Connection timed out: no furthe 内容由热心网友自发贡献,该文观点仅代表作者本人, 转载请联系作者并注明出处:https://m.elefans.com/xitong/1728550088a1163315.html, 本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容,一经查实,本站将立刻删除。
发表评论