Docker:网络配置
Docker运行容器时,一个常见的问题是:localhost(127.0.0.1)指向哪里?这涉及到Docker的网络配置问题。
Docker支持的网络模式如下:bridge(默认)、host、container、network-name、none。
桥接 bridge
Docker 默认的网络模式是 bridge 。在该模式下,docker 创建了一个 bridge,名称通常为 docker0
。
可以用ifconfig
来查看:
1 | docker0 Link encap:Ethernet HWaddr **:**:**:**:**:** |
宿主机和容器通过bridge进行通信,如图所示:
容器内的localhost指向容器内部。
本机 host
当使用 --net=host
启动容器时,网络配置为 host 模式。该模式下,容器和宿主机共享网络。形象地讲,容器和宿主机共享一个网卡,在容器内的网络访问如同直接在宿主机上操作一样。例如:
1 | docker run --rm -it --net=host ubuntu:trusty bash |
容器内的localhost指向宿主机。
container
Docker可以指定一个容器复用另一个容器的网络设置。这种模式适用于由多个容器搭建整套系统的情况,例如搭建PHP开发环境时,希望Mysql、Redis都使用PHP容器的网络配置,即可以使用该模式。
network-name
Docker允许用户使用Docker network driver或[第三方network driver插件](https://docs.docker.com/engine/extend/legacy_plugins/#network-plugins)创建自定义网络,然后多个容器都可以使用相同的网络。常见的第三方etwork driver插件有:Contiv Networking、Kuryr Network Plugin、Weave Network Plugin。
none
顾名思义,该模式下没有网络连接。例如我的宿主机ip为192.168.0.59,在容器内访问宿主机就提示无网络。
1 | docker run -it --net=none my_ubuntu bash |