news 2026/1/29 9:13:28

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

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
两个 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️⃣ 连接超时错误

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)

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/1/28 17:00:33

NopCommerce 4.9.3全栈开发实战 - 6.3 服务注册与依赖注入

1. 依赖注入概述 依赖注入(Dependency Injection,DI)是NopCommerce架构的核心设计模式之一,它允许对象通过构造函数、属性或方法接收其依赖项,而不是自己创建或查找依赖项。这种设计模式可以提高代码的可测试性、可维护…

作者头像 李华
网站建设 2026/1/29 6:59:18

AI原生应用开发:偏见缓解的工程化解决方案

AI原生应用开发:偏见缓解的工程化解决方案关键词:AI原生应用开发、偏见缓解、工程化解决方案、数据处理、算法优化摘要:本文聚焦于AI原生应用开发中偏见缓解的工程化解决方案。在AI快速发展的当下,应用中的偏见问题愈发凸显&#…

作者头像 李华
网站建设 2026/1/28 21:08:51

提示架构师2024最新能力模型:10大核心能力覆盖从Prompt到Agent全流程

2024提示架构师能力模型全解析:从Prompt设计到Agent落地的10大核心能力 标题选项 《2024提示架构师能力模型:从Prompt到Agent的全流程核心能力清单》《成为顶级提示架构师:2024最新10大能力覆盖AI应用全生命周期》《Prompt到Agent通关指南&am…

作者头像 李华
网站建设 2026/1/29 0:08:40

MinIO文件对象存储使用(C#)

开发软件程序特别是上传文件我们常常因为 地址的不正确或者性能或访问方式等等被烦扰的焦头烂额,这就是我们常使用的传统文件存储,今天我们将详细介绍文件对象存储系统,这是一种全新的存储解决方案。 接下来我详细从多个维度对传统文件存储和…

作者头像 李华
网站建设 2026/1/28 8:38:46

Trae AI零基础编程入门:纯小白也能快速上手

视频点击这里直接观看 1、简介 新中地推出Trae AI编程系列课程,本系列课程共分为三个模块,系统讲解Trae IDE的核心功能与实战应用,手把手教你学会Trae,提升编程效率。 PS. 针对纯小白,没有任何AI编程基础的同学也能…

作者头像 李华