运维(10) 解决Nacos服务注册使用Docker容器内网ip问题(指定注册ip或--network=host)

文章目录

      • 一、问题
      • 二、解决
        • 法一:`--network=host`
        • 法二: nacos指定注册ip

一、问题

使用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上如下:
运维(10) 解决Nacos服务注册使用Docker容器内网ip问题(指定注册ip或--network=host)_第1张图片


今日分享语句:
经历过黑暗,才有对光明的渴望;
经历过风雨,才懂得阳光的温暖;
经历过沧桑,才拥有温柔的内心;
经历人生最好的成长。

你可能感兴趣的:(★十二,运维☺★,docker,nacos服务注册,docker容器内网ip,指定注册ip,--network=host)