两个 Docker 容器如何通信?Docker 网络问题完整踩坑与解决指南

NebulaGraph Studio 连接失败?Docker 网络问题完整踩坑与解决指南(小白友好)

一、问题背景

我在本地使用 Docker 部署 NebulaGraph 集群 ,同时使用 Nebula Graph Studio(Web UI) 进行可视化管理。

  • Nebula Graph:docker-compose 启动
  • Nebula Studio:单独一个 Docker 容器
  • Studio 页面可以正常访问:
    👉 http://127.0.0.1:7001

但在 Studio 新建连接时,无论怎么填 IP,都会报错。


二、遇到的错误现象

1️⃣ 连接超时错误

text 复制代码
ErrBadRequest::failed to open connection
dial tcp 13.251.172.174:9669: i/o timeout

三、为什么会这样?(核心原理)

1️⃣ NebulaGraph 架构说明

NebulaGraph 并不是一个单体服务,而是由多个组件组成:

组件 作用 默认端口

nebula-studio Web 管理界面 7001

graphd 查询入口(真正连的服务) 9669

metad 元数据服务 9559

storaged 数据存储 9779

👉 Studio ≠ 数据库本身

👉 Studio 只是一个客户端,需要去连接 graphd

2️⃣ Docker 网络隔离是"真凶"

Docker 中有一个非常重要的概念:
不同 Docker network 之间的容器,默认是完全隔离的

我当时的网络结构是:

nebula-docker-compose_nebula-net ← Nebula Graph 集群
nebula-graph-studio-380_nebula-web ← Nebula Studio

📌 两个 network 不一样!
结果就是:
Studio 容器里 无法解析 graphd 容器名
nebula-graphd / nebula-docker-compose-graphd-1 都找不到
Docker DNS 返回 no such host

四、关键排查过程

1️⃣ 查看正在运行的容器

复制代码
docker ps

确认:

graphd / metad / storaged 正常运行

Studio 正常运行

2️⃣ 查看 Docker 网络

复制代码
docker network ls

发现:

Nebula Graph 和 Studio 在不同 network

五、正确解决方案(推荐做法)

✅ 核心思路

让 Nebula Studio 和 Nebula Graph 处在同一个 Docker network

Step 1:确认 Nebula Graph 的 network

复制代码
docker network ls

例如:

复制代码
nebula-docker-compose_nebula-net

Step 2:把 Studio 容器加入这个 network

复制代码
docker network connect nebula-docker-compose_nebula-net nebula-graph-studio-380-web-1

nebula-graph-studio-380-web-1 是 Studio 容器名

用 docker ps 可以确认

Step 3:重启 Studio(必须)

复制代码
docker restart nebula-graph-studio-380-web-1

六、Studio 中的正确连接方式

打开浏览器:

http://127.0.0.1:7001

新建连接,填写:

复制代码
Host: nebula-docker-compose-graphd-1
Port: 9669
Username: root
Password: nebula

📌 关键点:

Host 填的是 graphd 容器名
不是 127.0.0.1
不是公网 IP
是 Docker 内部 DNS 名称

两个 Docker 容器如何通信?

Docker 容器之间通信,优先使用:

👉 同一个 Docker network + 容器名(或 service name)

相关推荐
戮戮1 天前
Spring Cloud Gateway 零拷贝参数校验:一种高性能网关架构实践
java·网络·架构·gateway
虚伪的空想家1 天前
k8s集群configmap和secrets备份脚本
linux·容器·kubernetes
SXJR1 天前
k8s中的Pod
云原生·容器·kubernetes
[ ]8981 天前
Stack_MLAG_知识点梳理
网络·笔记·网络协议
上海云盾-小余1 天前
精准抵御流量攻击:高防 IP + 游戏盾组合部署实战详解
网络·tcp/ip·游戏
文静小土豆1 天前
K8s 滚动更新在 Java 应用中的实践与优化
java·容器·kubernetes
盟接之桥1 天前
盟接之桥®制造业EDI软件,打通全球供应链“最后一公里”,赋能中国制造连接世界
网络·安全·低代码·重构·汽车·制造
江畔何人初1 天前
TCP的三次握手与四次挥手
linux·服务器·网络·网络协议·tcp/ip
w6100104661 天前
CKA-2026-Ingress
云原生·容器·kubernetes·cka
志栋智能1 天前
超自动化巡检:实现运维“事前预防”的关键拼图
大数据·运维·网络·人工智能·机器学习·自动化