Docker系列(四):容器之间的网络通信
首先我们需要知道:两个容器要能通信,必须要有属于同一个网络的网卡。
先来看下正常情况下我们的容器默认是否是能通信的,这里运行两个测试容器:
docker run -it --name=bbox1 busybox
docker run -it --name=bbox2 busybox
然后我们进入bbox2容器中,并ping容器bbox1:
可以发现无法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查看:
然后我们重新运行前面的两个容器,并为他们指定netwoek:
docker run -it --network=my_net2 --name=bbox1 busybox
docker run -it --network=my_net2 --name=bbox2 busybox
然后在bbox2容器中ping容器bbox1:
使用 docker DNS 有个限制:只能在 user-defined 网络中使用。也就是说,默认的 bridge 网络是无法使用 DNS 的,这个我们在开始的时候就已经验证过了。
好了,大功告成!
【推荐】还在用 ECharts 开发大屏?试试这款永久免费的开源 BI 工具!
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步