Docker系列(四):容器之间的网络通信

首先我们需要知道:两个容器要能通信,必须要有属于同一个网络的网卡。

先来看下正常情况下我们的容器默认是否是能通信的,这里运行两个测试容器:

docker run -it --name=bbox1 busybox

docker run -it --name=bbox2 busybox

Docker系列(四):容器之间的网络通信_第1张图片

然后我们进入bbox2容器中,并ping容器bbox1:

Docker系列(四):容器之间的网络通信_第2张图片

可以发现无法ping通,这是因为容器默认的隔离原因导致的。

从 Docker 1.10 版本开始,docker daemon 实现了一个内嵌的 DNS server,使容器可以直接通过“容器名”通信。方法很简单,只要在启动时用 --name 为容器命名就可以了。

首先我们需要创建一个bridge类型的网桥:docker network create --driver bridge --subnet 172.22.16.0/24 --gateway 172.22.16.1 my_net2  

创建的同时为这个网桥指定了IP段,当然也可以不指定。

创建完成后可以通过 docker network ls查看:

Docker系列(四):容器之间的网络通信_第3张图片

然后我们重新运行前面的两个容器,并为他们指定netwoek:

docker run -it --network=my_net2 --name=bbox1 busybox

docker run -it --network=my_net2 --name=bbox2 busybox

然后在bbox2容器中ping容器bbox1:

Docker系列(四):容器之间的网络通信_第4张图片

使用 docker DNS 有个限制:只能在 user-defined 网络中使用。也就是说,默认的 bridge 网络是无法使用 DNS 的,这个我们在开始的时候就已经验证过了。

好了,大功告成!

 

你可能感兴趣的:(Docker系列(四):容器之间的网络通信)