背景
在项目中使用到了spring cloud alibaba,现有三台宿主机都部署有docker环境。通过docker-compose管理docker服务。均使用默认配置。
初始配置
nd-gateway:
container_name: nd-gateway
build:
context: backend/nd-gateway
dockerfile: dockerfile
args:
- xms=-Xms750m
- xmx=-Xmx750m
ports:
- "8081:8081"
extra_hosts:
- "sql.server:121.227.31.94"
- "redis.server:192.168.0.51"
- "nacos.server:192.168.0.10"
问题
其余配置和上面配置相同。并通过该配置在三台服务器上分别起了三个均衡服务。当通过gateway访问后端时出现连接超时问题。后发现注册到nacos的IP地址是docker虚拟网桥地址,
解决思路
本次服务之前就遇到过同样的问题,由于服务间互访都是通过ip:port方式访问,之前的解决方案是通过ip route方式加路由方式将不同服务器上的不同网桥打通。本次不讨论。
本次思路是:
通过docker-compose将宿主机服务器ip当作环境变量写进docker容器,然后通过配置读取环境变量,修改注册到nacos的IP地址。通过宿主机ip:port访问则不存在这种问题
解决方案
目录
common.env docker-compose.yml
docker-compose.yml部分内容
nd-gateway:
container_name: nd-gateway
build:
context: backend/nd-gateway
dockerfile: dockerfile
args:
- xms=-Xms750m
- xmx=-Xmx750m
ports:
- "8081:8081"
extra_hosts:
- "sql.server:121.227.31.94"
- "redis.server:192.168.0.51"
- "nacos.server:192.168.0.10"
env_file: common.env
common.env内容
hostIp=192.168.0.166
TZ=Asia/Shanghai
配置好基础环境之后
去配置springboot项目配置
spring:
cloud:
nacos:
discovery:
ip: ${hostIp}
配置完后,注册在nacos上的IP则为宿主机ip,互访就不会出现问题