当 Docker 启动时,会自动在宿主机上创建一个 docker0 虚拟网桥,实际上是Linux 的一个 bridge。

Docker 随机分配一个本地未占用的私有网络(在RFC1918中定义)中的一个地址给 docker0接口。比如典型的 172.17.0.1,掩码为255.255.0.0。

此后启动的容器内的网口也会自动分配一个网段(172.17.0.0/16)的地址。

当创建一个 Docker 容器的时候,同时会创建一个 veth pair 接口(当数据包发送到一个接口时,另外一个接口也可以接收相同的数据包)。这对接口一端在容器内,即 eth0;另一端在本地并被挂载到docker0 网桥,名称以veth 开头(例如 veth4c45933)。通过这种方式,主机可以跟容器通信,容器之间也可以相互通信。Docker 就创建了在主机和所有容器之间的一个虚拟共享网络。

Docker 网络相关的命令

  1. 只有在Docker 服务启动的时候才能配置,而且不能马上生效的有:
  2.  
  3. -b BRIDGE or --bridge=BRIDGE --指定容器挂载的网桥
  4. --bip=CIDR            --定制docker0的掩码
  5. -H SOCKET... or --host=SOCKET... --Docker服务端接收命令的通道
  6. --icc=true|false         --是否支持容器之间进行通信
  7. --ip-forward=true|false     --请看下文容器之间的通信
  8. --iptables=true|false      --是否允许Docker添加iptables规则
  9. --mtu=BYTES          --容器网络中的MTU
  10.  
  11. 既可以在启动服务时指定,也可以 Docker容器启动(docker run)时候指定。在Docker 服务启动的时候指定则会成为默认值,后面执行 docker run 时可以覆盖设置的默认值:
  12.  
  13. --dns=IP_ADDRESS...   --使用指定的DNS服务器
  14. --dns-search=DOMAIN... --指定DNS搜索域
  15.  
  16. 只有在 docker run 执行时使用,因为它是针对容器的特性内容:
  17.  
  18. -h HOSTNAME or --hostname=HOSTNAME --配置容器主机名
  19. --link=CONTAINER_NAME:ALIAS       --添加到另一个容器的连接
  20. --net=bridge|none|container:NAME_or_ID|host --配置容器的桥接模式
  21. -p SPEC or --publish=SPEC       --映射容器端口到宿主主机
  22. -P or --publish-all=true|false    --映射容器所有端口到宿主主机

自定义网桥

除了默认的 docker0 网桥,也可以指定网桥来连接各个容器

在启动Docker 服务的时候, 使用 -b BRIDGE 或 --bridge=BRIDGE 来指定使用的网桥

1)添加网桥

  1. [root@server ~]# systemctl stop docker  #停止docker服务
  2. [root@server ~]# ip link set dev docker0 down  #停止docker0网桥
  3. [root@server ~]# brctl delbr docker0  #删除docker0网桥
  4.  
  5. [root@server ~]# brctl addbr bridge0  #新建bridge0网桥
  6. [root@server ~]# ip addr add 192.168.2.1/ dev bridge0  #绑定ip给bridge0网桥
  7. [root@server ~]# ip link set dev bridge0 up  #启动bridge0网桥
  8. [root@server ~]# brctl show   #查看网桥信息
  9. bridge name bridge id STP enabled interfaces
  10. bridge0 8000.000000000000 no
  11. virbr0 .525400caf93e yes virbr0-nic
  12. [root@server ~]# ifconfig bridge0  #查看bridge0网桥信息
  13. bridge0: flags=<UP,BROADCAST,RUNNING,MULTICAST> mtu
  14. inet 192.168.2.1 netmask 255.255.255.0 broadcast 0.0.0.0

2)配置docker服务

  1. [root@server ~]# vim /lib/systemd/system/docker.service  #由于新版本的没有/etc/default/docker配置文件,so 需要自己添加。
  2. ExecStart=/usr/bin/dockerd -H unix:// $DOCKER_OPTS  #在ExecStart末尾添加 $DOCKER_OPTS
  3. EnvironmentFile=-/etc/default/docker    #指定配置文件的路径
  4.  
  5. [root@server ~]# vim /etc/default/docker  #自定义编辑配置文件,写入启动指定网桥的网桥信息
  6. DOCKER_OPTS="-b=bridge0"
  7.  
  8. [root@server ~]# systemctl start docker  #启动docker服务
  9. [root@server ~]# docker run --rm -ti --name Mycentos centos /bin/bash  #创建一个容器
  10.  
  11. [root@0a13bd05faae /]# ifconfig  #查看容器的ip地址,检查是否桥接到birdge0上面
  12. eth0: flags=<UP,BROADCAST,RUNNING,MULTICAST> mtu
  13. inet 192.168.2.2 netmask 255.255.255.0 broadcast 192.168.2.255
  14.  
  15. [root@0a13bd05faae /]# ping 192.168.2.1  #测试和网桥是否通

创建点vs点的连接

默认情况下,Docker 会将所有的容器连接到由 docker0 提供的虚拟子网中。如果我们需要两个容器之间可以通信,而不通过宿主机网桥进行桥接。

解决办法:创建一对 peer 接口,分别放到两个容器中,配置成点对点链路类型即可。

1)启动容器

  1. [root@server ~]# docker run -i -t --rm --name myCentos01 --net=none centos /bin/bash  #在第一个终端启动第一个容器
  2.  
  3. [root@server ~]# docker run -i -t --rm --name myCentos02 --net=none centos /bin/bash  #在第二个终端启动第二个容器

2)找到进程号,然后创建网络命名空间的跟踪文件(在第三个终端操作)

  1. [root@server ~]# docker inspect -f '{{.State.Pid}}' myCentos01  #找到myCentos01的进程号
  2.  
  3. [root@server ~]# docker inspect -f '{{.State.Pid}}' myCentos02  #找到myCentos02的进程号
  4.  
  5. [root@server ~]# mkdir -p /var/run/netns
  6. [root@server ~]# ln -s /proc//ns/net /var/run/netns/
  7. [root@server ~]# ln -s /proc//ns/net /var/run/netns/

3)创建一对 peer 接口,然后配置路由(在第三个终端操作)

  1. [root@server ~]# ip link add A type veth peer name B
  2. [root@server ~]#
  3. [root@server ~]# ip link set A netns
  4. [root@server ~]# ip netns exec ip addr add 10.1.1.1/ dev A
  5. [root@server ~]# ip netns exec ip link set A up
  6. [root@server ~]# ip netns exec ip route add 10.1.1.2/ dev A
  7. [root@server ~]#
  8. [root@server ~]# ip link set B netns
  9. [root@server ~]# ip netns exec ip addr add 10.1.1.2/ dev B
  10. [root@server ~]# ip netns exec ip link set B up
  11. [root@server ~]# ip netns exec ip route add 10.1.1.1/ dev B

4)分别进入连个容器内进行ping测试。

docker的网络(5)的更多相关文章

  1. docker的网络-Container network interface(CNI)与Container network model(CNM)

    Overview 目前围绕着docker的网络,目前有两种比较主流的声音,docker主导的Container network model(CNM)和社区主导的Container network in ...

  2. Docker 基础 : 网络配置

    大量的互联网应用服务包含多个服务组件,这往往需要多个容器之间通过网络通信进行相互配合.Docker 目前提供了映射容器端口到宿主主机和容器互联机制来为容器提供网络服务.接下来我们将讲述 Docker ...

  3. Docker(四):Docker基本网络配置

    1.Libnetwork Libnetwork提出了新的容器网络模型简称为CNM,定义了标准的API用于为容器配置网络. CNM三个重要概念: 沙盒:一个隔离的网络运行环境,保存了容器网络栈的配置,包 ...

  4. docker(4)docker的网络,自定义网桥

    Docker 的网络 运行 ifconfig 找到 docker0 : 虚拟网卡默认网卡名称为docker0 查看docker 的网桥: 我这里默认们没有进行安装 网桥管理设备:进行安装一下: yum ...

  5. 5、Docker容器网络

    使用Linux进行IP层网络管理的指     http://linux-ip.net/html/ # yum install iproute http://linux-ip.net/html/tool ...

  6. docker的网络访问

    Docker的网络访问: #systemctl  start docker #ifconfig [root@zizhen02 ~]# ifconfig docker0: flags=4099<U ...

  7. docker单机网络类型

    docker单机网络类型概述 Docker 安装时会自动在 host 上创建三种网络  分别为 bridge    host   none .   可用 docker network ls 命令查看 ...

  8. Docker的网络类型和固定IP设置

    Docker的网络机制 Docker的网络有三种类型(driver): bridge, host 和 null. birdge: 就如同桥接的switch/hub, 使用bridge网络的contai ...

  9. docker之 网络模式和跨主机通信

    Docker的四种网络模式Bridge模式 当Docker进程启动时,会在主机上创建一个名为docker0... Docker的四种网络模式 Bridge模式 当Docker进程启动时,会在主机上创建 ...

  10. docker的网络模式

    记性不好,回顾一下.按照惯例,直接看官文. Docker's networking subsystem is pluggable, using drivers. Several drivers exi ...

随机推荐

  1. C++ 按址操作

    一.指针 二.变量与指针 注意区别char 和char *. !!!!!!! 二.函数与指针 #include<iostream> #include<string> using ...

  2. 尴尬,通篇使用 if

    以给博客园头部导航条链接添加图标为例, 接下来看看如何分别使用对象.数组.Map 优化它的. 前置 1.接下来给头部导航条添的图标包含: 博客园首页 新随笔 博客首页 联系 订阅 管理 2.这里封装了 ...

  3. Codeforces Round #628 (Div. 2)

    1325A - EhAb AnD gCd 题意:随意找两个数是他们的最大公约数 GCD 与最小公倍数 LCM 之和为所给定的值. 思路:找一下规律 ,假设所给的 数位n, 那么我们将n分成 1 ,n- ...

  4. 如何基于layui的laytpl实现数据绑定

    想了半天才想起自己园子的登录密码.可想而知,多长时间没登录了 正文一开始用layui做了几个管理系统,所以用起来觉得确实很容易上手,管理后台最常用的就是form和table以及弹窗类.layui提供的 ...

  5. 获取data 数据

    export function getData(el, name, val) { const prefix = 'data-' if (val) { return el.setAttribute(pr ...

  6. PTA数据结构与算法题目集(中文) 7-8

    PTA数据结构与算法题目集(中文)  7-8 7-8 哈利·波特的考试 (25 分)   哈利·波特要考试了,他需要你的帮助.这门课学的是用魔咒将一种动物变成另一种动物的本事.例如将猫变成老鼠的魔咒是 ...

  7. Prthon多线程和模块

    Prthon多线程和模块 案例1:简化除法判断 案例2:分析apache访问日志 案例3:扫描存活主机 案例4:利用多线程实现ssh并发访问 1 案例1:简化除法判断 1.1 问题 编写mydiv.p ...

  8. Nginx-高性能的反向代理服务器

    Nginx Nginx作为一款反向代理服务器,现在大多数网站都有使用,自己在项目中几乎都有用到,自己的网站也使用到了它. 了解Nginx 上面图可以直观的看出Nginx的用处,可以将请求转发至Web服 ...

  9. MySQL学习之路3-MySQL中常用数据类型

    MySQL中常用数据类型 字符型 存储字符型数据.例如姓名,地址,电话号码等.使用引号括起来,一般使用单引号. 常用类型: char(255) 定长字符串,最大长度255个字符. varchar(25 ...

  10. python3(三十六)StringIO BytesIO

    """ StringIO和BytesIO """ __author__on__ = 'shaozhiqi 2019/9/23' # !/us ...