20.5 配置docker0网桥

Docker服务默认会创建一个名称为docker0的Linux网桥(其上有一个docker0内部接口),它在内核层连通了其他的物理或虚拟网卡,这就将所有容器和本地主机都放到同一个物理网络。用户使用Docker创建多个自定义网络时可能会出现多个容器网桥。

Docker默认指定了docker0接口的IP地址和子网掩码,让主机和容器之间可以通过网桥相互通信,它还给出了MTU(接口允许接收的最大传输单元),通常是1500字节,或宿主主机网络路由上支持的默认值。这些值都可以在服务启动的时候进行配置:

·—bip=CIDR——IP地址加掩码格式,例如192.168.1.5/24;

·—mtu=BYTES——覆盖默认的Docker mtu配置。

也可以在配置文件中配置DOCKER_OPTS,然后重启服务。由于目前Docker网桥是Linux网桥,用户可以使用brctl show来查看网桥和端口连接信息:


  1. $ sudo brctl show
  2. bridge name bridge id STP enabled interfaces
  3. docker0 8000.3a1d7362b4ee no veth65f9
  4. vethdda6

20.5 配置docker0网桥 - 图1注意

brctl命令如果系统中没有自带,可以使用sudo apt-get install bridge-utils来安装(Debian、Ubuntu系列系统)。

每次创建一个新容器的时候,Docker从可用的地址段中选择一个空闲的IP地址分配给容器的eth0端口。并且使用本地主机上docker0接口的IP作为容器的默认网关:


  1. $ docker run -i -t --rm base /bin/bash
  2. $ ip addr show eth0
  3. 24: eth0: <BROADCAST,UP,LOWER_UP> mtu 1500 qdisc pfifo_fast state UP group
  4. default qlen 1000
  5. link/ether 32:6f:e0:35:57:91 brd ff:ff:ff:ff:ff:ff
  6. inet 172.17.0.3/16 scope global eth0
  7. valid_lft forever preferred_lft forever
  8. inet6 fe80::306f:e0ff:fe35:5791/64 scope link
  9. valid_lft forever preferred_lft forever
  10. $ ip route
  11. default via 172.17.42.1 dev eth0
  12. 172.17.0.0/16 dev eth0 proto kernel scope link src 172.17.0.3
  13. $ exit

目前,Docker不支持在启动容器时候指定IP地址。

20.5 配置docker0网桥 - 图2注意

实际上,Linux网桥自身功能已经十分完备,也可以替换为OpenvSwitch等功能更强大的网桥实现。