运维(10) 解决Nacos服务注册使用Docker容器内网ip问题(指定注册ip或--network=host)
·
一、问题
使用docker集群部署的jar启动时注册到nacos上的ip会使用docker的内网ip作为注册地址,导致多台服务器部署服务时,nacos监听到的服务永远只有一个
二、解决
法一:--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上如下:
今日分享语句:
经历过黑暗,才有对光明的渴望;
经历过风雨,才懂得阳光的温暖;
经历过沧桑,才拥有温柔的内心;
经历人生最好的成长。
更多推荐
已为社区贡献16条内容
所有评论(0)