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

拼搏现实的明天。 2022-09-11 13:26 632阅读 0赞

文章目录

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

一、问题

使用docker集群部署的jar启动时注册到nacos上的ip会使用docker的内网ip作为注册地址,导致多台服务器部署服务时,nacos监听到的服务永远只有一个

二、解决

可参考: https://github.com/alibaba/nacos/issues/310

法一:--network=host

示例

  1. 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配置文件中添加如下配置即可

  1. spring:
  2. cloud:
  3. nacos:
  4. discovery:
  5. ip: xx
  6. port: xx

java程序运行时动态传递ip和端口号如下:

  1. -Dspring.cloud.nacos.discovery.ip=xx -Dspring.cloud.nacos.discovery.port=xxx
  2. # 示例
  3. java -jar -Dspring.cloud.nacos.discovery.ip=www.zhengqingya.com app.jar

注册到nacos上如下:
在这里插入图片描述


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

发表评论

表情:
评论列表 (有 0 条评论,632人围观)

还没有评论,来说两句吧...

相关阅读