Docker

Docker 容器之间网络的通信

Posted on 2020-10-20,2 min read

容器之间互通

Docker在创建容器时有四种网络模式:bridge/host/container/none,bridge为默认不需要用–net去指定,其他三种模式需要在创建容器时使用–net去指定

bridge模式(默认模式)

 docker run时使用--net=bridge,这种模式会为每个容器分配一个独立的Network Namespace,

 同一个宿主机上的所有容器会在同一个网段下,相互之间是可以通信的

 注1:bridge为默认模式,不需要使用参数--net去指定,使用了--net参数反而无效

 注2:bridge模式无法指定容器IP(但非绝对

host模式

 docker run时使用--net=host,容器将不会虚拟出IP/端口,而是使用宿主机的IP和端口

 docker run -itd --net=host 961769676411

 注1:host模式不能使用端口映射和自定义路由规则,这些都与主机一致,-p 与-icc 参数是无效的

新建两个容器

docker run -d --name box1 busybox /bin/sh -c "while true;do sleep 3600;done"

docker run -d --name box2 busybox /bin/sh -c "while true;do sleep 3600;done"

进入box1 ping box2

docker exec -it ac1aa7242949 /bin/sh
ping 172.17.0.3

表明新建的两个容器之间是可以互通的,他们之间通过bridge docker0进行通信,docker0为他们分别组了一对

img

为新建的容器指定bridge网络

创建新的bridge网络

docker network ls 查看现在的网络

docker network create -d bridge dockerBridge 创建自己的bridge

创建容器并且指定bridge

docker run -d --name box5 --network dockerBridge busybox /bin/sh -c "while true;do sleep 3600;done"

docker run -d --name box6 --network dockerBridge busybox /bin/sh -c "while true;do sleep 3600;done"

运用自己的创建的bridge两个容器之间会自动link

docker exec -it ac1aa7242949 /bin/sh
ping box5

下一篇: sealos+rook 部署 kubeSphere+TiDB→