Hello! 欢迎来到小浪云!


怎样在docker中配置网络连接? network有哪些常用命令?


docker 中配置网络连接的关键在于理解容器通信方式及使用网络驱动管理。docker 提供 bridge、host、none 等默认网络模式,其中 bridge 是默认模式,通过虚拟网桥实现私有 ip 通信;host 模式共享宿主机网络,none 则无网络接口。用户可通过 docker network ls 查看网络,并在运行容器时用 –network 指定使用特定网络。其次推荐使用自定义 bridge 网络以支持自动 dns 解析,命令为 docker network create my_network,再运行多个容器加入该网络即可通过服务名通信。常见问题包括:容器不在同一网络、端口未暴露、防火墙限制等,应统一网络配置并使用服务名访问。此外还支持 overlay(用于 swarm)、macvlan、ipvlan 等高级网络类型,以及第三方插件如 calico 扩展功能。掌握这些核心点即可满足多数部署需求。

怎样在docker中配置网络连接? network有哪些常用命令?

在 Docker 中配置网络连接,核心是理解容器之间的通信方式以及如何通过网络驱动管理它们。Docker 提供了多种内置网络驱动,也支持自定义网络插件,可以灵活地满足不同场景下的网络需求。


1. 理解 Docker 的默认网络模式

Docker 安装后会自带几个默认的网络,比如 bridge、host 和 none。这几种模式决定了容器与宿主机之间、容器与容器之间的通信方式。

  • bridge:这是默认模式,每个容器会被分配一个私有 IP,并通过虚拟网桥进行通信。
  • host:容器直接使用宿主机的网络,没有隔离,适合对网络性能要求高的场景。
  • none:容器没有网络接口,适用于完全隔离的环境。

你可以用以下命令查看当前所有网络:

docker network ls

如果想让容器使用特定网络,可以在运行时指定:

docker run --network host nginx

2. 创建和管理自定义 Bridge 网络

虽然默认的 bridge 网络能用,但推荐使用自定义的 bridge 网络,因为它支持自动 DNS 解析,方便容器间通过服务名通信。

创建自定义网络:

docker network create my_network

运行两个容器并加入这个网络:

docker run -d --name web --network my_network nginx docker run -d --name app --network my_network myapp

这时候你就可以在 app 容器里直接通过 web 这个名字访问 Nginx 容器了。

常用操作命令包括:

  • 查看某个网络的详细信息:

    docker network inspect my_network
  • 删除不再使用的网络:

    docker network rm my_network

3. 容器间通信的常见问题及解决方法

有时候容器无法互相访问,常见的原因有几个:

  • 容器不在同一个网络中。确保多个容器都加入了相同的自定义网络。
  • 没有正确暴露端口。启动容器时记得加上 -p 参数映射端口。
  • 防火墙或 SELinux 设置限制了访问。检查宿主机的防火墙规则。

举个例子,如果你运行了一个 mysql 容器,另一个应用容器连不上它,可能是因为没加 –network 或者用了默认 bridge(不支持自动解析)。

解决办法就是统一加入自定义网络,并使用服务名作为主机名来连接。


4. 其他网络类型和高级用法(可选)

除了常用的 bridge 网络,Docker 还支持一些更复杂的网络类型:

  • overlay:用于多主机通信,常用于 Docker Swarm。
  • macvlan:给容器分配 MAC 地址,使其在网络中看起来像物理设备。
  • ipvlan:类似 macvlan,但共享 MAC 地址。

这些网络类型通常在特定场景下使用,例如需要容器拥有独立公网 IP 时才考虑。

此外,还可以使用第三方插件扩展网络功能,如 Calico、Weave 等,实现更强大的网络策略控制。


基本上就这些内容了。配置 Docker 网络不复杂,但容易忽略细节,尤其是容器间的通信逻辑。掌握好这几个关键点,基本能满足大多数部署需求。

相关阅读