一、问题
使用docker集群部署的jar启动时注册到nacos上的ip会使用docker的内网ip作为注册地址,导致多台服务器部署服务时,nacos监听到的服务永远只有一个
二、解决
可参考: https://github.com/alibaba/nacos/issues/310
法一: --network=host
docker run -d --network=host --name app-demo registry.cn-hangzhou.aliyuncs.com/zhengqing/app-demo
使用--network=host主机网络模式,容器运行时将会使用宿主机的网络信息,即会拿到宿主机的ip注册到nacos上;
这个时候我们无需-p 80:80指定服务端口运行,因为--network=host模式会使用服务本身启用的端口。
法二: nacos指定注册ip
bootstrap.yml配置文件中添加如下配置即可
spring:
cloud:
nacos:
discovery:
ip: xx
port: xx
java程序运行时动态传递ip和端口号如下:
-Dspring.cloud.nacos.discovery.ip=xx -Dspring.cloud.nacos.discovery.port=xxx
# 示例
java -jar -Dspring.cloud.nacos.discovery.ip=www.zhengqingya.com app.jar
注册到nacos上如下: