容器之间可以IP,Docker DNS server或joined容器三种方式。
IP通信
从之前的例子可以得出这样一个结论:两个容器要能通信,必须要有属于同一个网络的网卡。满足这个条件后,容器就可以通过IP通信了。具体做法是在容器创建时通过 --network 指定相应的网络,或者通过docker network connect将现有容器加入指定网络
从下面的图中我们可以看到通过容器的ip进行通信
Docker DNS Server
通过IP访问容器虽然满足了通信的需求,但是不够灵活。因为我们在部署应用之前可能无法确定IP,部署之后再指定要访问的IP会比较麻烦。对于这个问题,通过docker自带的DNS服务解决。
从图中可以看到通过DNS bbox1 ping 不通bbox2,这是因为使用 docker DNS 有个限制:只能在 user-defined 网络中使用。也就是说,默认的 bridge 网络是无法使用 DNS 的。下面验证一下:
我们通过--network=my_net2自定义的网络创建容器
从下图中可以看到通过域名bbox3可以ping通bbox4
joined容器
joined容器是一种实现容器间通信的方式。
joined容器非常特别,它可以使多个容器共享一个网络栈,共享网卡和配置信息,joined容器之间可以通过127.0.0.1直接通信
先创建web1容器,通过--network=container:web1使用web1容器的网络,在图中也可以看到bbox5和web1的网卡信息是一致的
在容器bbox5中可以通过访问127.0.0.1访问到web1容器