docker network connect

描述将容器连接到网络
用法docker network connect [OPTIONS] NETWORK CONTAINER

描述

将容器连接到网络。您可以通过名称或 ID 连接容器。连接后,容器可以与同一网络中的其他容器通信。

选项

选项默认值描述
--alias为容器添加网络范围别名
--driver-opt网络的驱动程序选项
--ipIPv4 地址 (例如:172.30.100.104)
--ip6IPv6 地址 (例如:2001:db8::33)
--link添加与另一个容器的链接
--link-local-ip为容器添加链接本地地址

示例

将正在运行的容器连接到网络

$ docker network connect multi-host-network container1

在容器启动时将其连接到网络

您也可以使用docker run --network=选项启动容器并立即将其连接到网络。

$ docker run -itd --network=multi-host-network busybox

指定容器在给定网络上使用的 IP 地址 (--ip)

您可以指定要分配给容器接口的 IP 地址。

$ docker network connect --ip 10.10.36.122 multi-host-network container2

您可以使用--link选项链接另一个容器并使用首选别名。

$ docker network connect --link container1:c1 multi-host-network container2

为容器创建网络别名 (--alias)

--alias选项可用于在连接到的网络中通过另一个名称解析容器。

$ docker network connect --alias db --alias mysql multi-host-network container2

设置容器接口的 sysctl (--driver-opt)

可以使用--driver-opt标签com.docker.network.endpoint.sysctls为每个接口设置以net.ipv4.net.ipv6.开头的sysctl设置。接口名称必须替换为IFNAME

要为接口设置多个sysctl,请引用driver-opt字段的整个值,如有必要,请记住为 shell 转义引号。例如,如果my-net的接口名为eth3,则以下示例设置net.ipv4.conf.eth3.log_martians=1net.ipv4.conf.eth3.forwarding=0

$ docker network connect --driver-opt=\"com.docker.network.endpoint.sysctls=net.ipv4.conf.IFNAME.log_martians=1,net.ipv4.conf.IFNAME.forwarding=0\" multi-host-network container2

注意

网络驱动程序可能会限制可以修改的 sysctl 设置,并且为了保护网络的运行,将来可能会添加新的限制。

停止、暂停或重启容器的网络影响

您可以暂停、重启和停止连接到网络的容器。容器在运行时会连接到其配置的网络。

如果指定了容器的IP地址,则在重启停止的容器时会重新应用该地址。如果IP地址不再可用,则容器将无法启动。确保IP地址可用的一种方法是在创建网络时指定--ip-range,并从该范围之外选择静态IP地址。这确保了在该容器不在网络上时,不会将IP地址分配给其他容器。

$ docker network create --subnet 172.20.0.0/16 --ip-range 172.20.240.0/20 multi-host-network
$ docker network connect --ip 172.20.128.2 multi-host-network container2

要验证容器是否已连接,请使用docker network inspect命令。使用docker network disconnect命令将容器从网络中移除。

连接到网络后,容器只需使用其他容器的IP地址或名称即可进行通信。对于支持多主机连接的overlay网络或自定义插件,连接到同一多主机网络但从不同引擎启动的容器也可以通过这种方式进行通信。

您可以将一个容器连接到一个或多个网络。这些网络不必是同一类型。例如,您可以将单个容器连接到桥接网络和覆盖网络。