解决docker项目部署之Nacos服务注册IP选择

水深无声 2023-10-11 17:21 120阅读 0赞

前段时间为了方便项目的快速部署,我便将其项目部署到了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选择地址

  1. 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中配置如下:

  1. spring:
  2. cloud:
  3. inetutils:
  4. preferredNetworks:
  5. - 192.168
  6. - 10.0

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

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

发表评论

表情:
评论列表 (有 0 条评论,120人围观)

还没有评论,来说两句吧...

相关阅读