部署在docker的nacos获取其他服务器中docker的springboot jar项目ip地址不正确的问题

问题描述

比如我们有一个服务器A和服务器B,在服务器A中使用docker部署了一个nacos服务和一个gateway网关服务,在服务器B中部署一个Api服务。当正常启动三个服务后,我们访问网关请求Api服务时会发现超时熔断,查看nacos的Api服务配置中,ip一栏也不是我们B服务器的内网。

问题分析

其实原因很简单,docker启动容器后nacos上注册的ip是docker内的虚拟ip,每一个docker容器都会跟宿主机侨联获取一个虚拟ip暴露出来,而且nacos获取到的便是这个docker的 虚拟ip,而且gateway网关解析后请求会使用这个虚拟ip,在实体服务器AB中并不存在这个ip,所以会超时。

解决办法

如果你使用docker-compose来构建的镜像

在services中有network_mode属性,给他设置host即可!

services:
  base:
    build: base
    container_name: base_1
    network_mode: "host"  # 与宿主机共有一个IP
    ports:
如果你直接run docker镜像

在run 语句后面加上--network=host 即可

docker run -d --network=host -p 8080:8080 api-1.0

讲解

上面的解决办法是将docker直接挂在宿主机上,也可以说是把宿主机的ip信息赋给docker。这样你需要注意些问题,因为内部服务(如:Tomcat)已经被docker挂载出来了,那么也其实就没有必要指定-p 8080:8080 了,因为此时docker的端口后就是内部服务的端口后,不需要使用-p指令来建立对应关系了。向下面这截图一样,ports中是没有任何端口信息的。

但是可能因为版本过老的问题,我的run指令上还是必须写上-p 8080:8080 ,去掉不行,你们大家可以自己试试去掉后行不行

在这里插入图片描述

猜你喜欢

转载自blog.csdn.net/jxysgzs/article/details/108095792