前段时间为了方便项目的快速部署,我便将其项目部署到了docker中,后来有一次项目调试的时候我发现我在本地启动的项目,无法通过fegin调用我部署在docker里面的服务
在这里插入图片描述

我就立刻去nacos里查看项目的启动情况,突然发现其注册的地址是docker内部的物理机地址
在这里插入图片描述

然后我就去查了一下SpringCloud的官方文档,发现有一项配置如下:

Sometimes, it is useful to ignore certain named network interfaces so that they can be excluded from Service Discovery registration (for example, when running in a Docker container). A list of regular expressions can be set to cause the desired network interfaces to be ignored.
You can also force the use of only specified network addresses by using a list of regular expressions.

翻译出来就是:

有时,忽略某些命名的网络接口很有用,这样就可以将它们从服务发现注册中排除(例如,在Docker容器中运行时)。可以设置正则表达式列表,以忽略所需的网络接口。还可以通过使用正则表达式列表,强制只使用指定的网络地址。

那么怎解决呢?
解决办法很简单就是强制指定物理机的ip选择地址

spring.cloud.nacos.discovery.ip=192.168.1.2

注意后面的ip地址就是我docker所在的服务器ip地址


虽然问题解决了,但是还是要更深入的了解一下这个IP选择的逻辑。翻了一通源码发现,其大致逻辑如下:
在这里插入图片描述

代码思路很简单:
Nacos首先检查有没有ip及networkInterface配置,如果有则使用配置的IP,否则检查networkInterface,并获取IP,如果两者都为空,则使用inetUtils.findFirstNonLoopbackHostInfo().getIpAddress()来获取IP
在这里插入图片描述

而findFirstNonLoopbackHostInfo()的部分逻辑如下:
在这里插入图片描述

它最终会返回一个匹配的IPV4地址,并且排除本机回环网络(127.0.0.0-127.255.255.255),并且匹配是否是首选网络(如果配置了preferredNetworks)。
下面我再说一下另外一个解决方案:preferredNetworks是怎么用的
在springCloud中配置如下:

spring:
  cloud:
	inetutils:
	  preferredNetworks:
		- 192.168
		- 10.0

如果我们是使用的SpringCloud-alibaba注册到Nacos 也有相应的配置:

spring.cloud.nacos.discovery.networkInterface=192.168
Logo

为开发者提供学习成长、分享交流、生态实践、资源工具等服务,帮助开发者快速成长。

更多推荐