问题描述
比如我们有一个服务器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
,去掉不行,你们大家可以自己试试去掉后行不行