解决Nacos服务注册使用Docker容器内网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上如下:

在这里插入图片描述

 


版权声明:本文为qq_39458487原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接和本声明。