Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

docker swarm 集群环境 dubbo 注册 IP 默认为 docker_gwbridge IP 导致无法获取元数据 #3075

Open
arielly opened this issue Dec 10, 2024 · 0 comments

Comments

@arielly
Copy link

arielly commented Dec 10, 2024

docker swarm 集群环境 Docker Engine Version 23.0.6
使用镜像 nacos-server:v2.3.2
Spring boot 应用 Maven 依赖
nacos-discovery-spring-boot-starter 0.3.0-RC
dubbo-spring-boot-starter 3.2.14

现在的问题是,容器应用在 nacos 注册中心注册的 dubbo 实例 IP 是读取的 docker_gwbridge IP (172.18.0.9) 而不是容器 overlay IP (10.0.1.18)
这样导致,位于不同宿主机上的容器 dubbo 服务注册,消费者获取不到提供者的元数据
原因是,docker_gwbridge IP 是基于宿主机分配的桥接网络地址(scope: local),不同的宿主机容器之间是不可以通过这个 IP 来互相访问
容器间的访问,是应该基于服务名(无法通过 dubbo.protocal.host 注册)或是 overlay IP (scope: swarm) 来访问的

网络是没有问题的,进入容器后 $(docker exec -it container-id)
容器之间通过 curl {overlay IP} 访问测试,是没有任何问题的
显而易见,只要将 容器的 overlay IP 注册到 nacos 中心,就应该能解决问题,但我不知道如何去进行控制。

在 docker swarm 中,采用 host 模式部署是可行的,但这样无法进行有效的容器 scale。
我需要的是,在容器进行 scale 时,通过 swam 集群动态分配给容器的 overlay ip 来解决容器间的 dubbo 服务调用。

@arielly arielly changed the title Web docker swarm 集群环境 dubbo 注册 IP 默认为 docker_gwbridge IP 导致无法获取元数据 Dec 10, 2024
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

1 participant