我们接着盗图,如下:

在这张图上,可以看到,如果两个容器使用同一个bridge,那么两个容器之间是互相能通的

可以看到两个容器在同一个bridge下是可以互相ping通的

当两个容器在不同的bridge的时候,容器之间是不能ping通的,(但是不同bridge的容器为什么能ping通不同bridge的网关呢?)和拓扑图是一样的

如何让两个不同的网段之间能够ping通呢?

1.增加路由

如果host上对每个网络都有一个路由,同时操作系统上打开了ip forwarding,host就成了一个路由,挂在不同的网桥上的网络就能够互相ping通

我们可以看一下host上是否满足这个条件

ip r查看路由表

我们可以看到这些网段的路由表都定义好了,那我们再看一下ip forwarding

/proc/sys/net/ipv4/ip_forward,这里面本来是0,我们将他改成1

我们开启路由转发后不同bridge之间是否能通信呢?

可以看到ping向其他bridge的ip还是不能通,但是ping到网关是能通的

2.为什么已经开启了路由转发,还是不能互相通信啊?是不是因为防火墙?但是我的firewalld 和selinux都已经全部关闭了啊

但是linux内核还有个iptables,我们看一下iptables规则

可以看到bridge被iptables给DROP掉了,从命名规则 DOCKER-ISOLATION可知:docker 在设计上就是要隔离不同的network

那是不是我们更改一下iptables的规则就可以实现不同bridge容器间的通信呢,答案是肯定的(由于本人iptables特别不好,所以这里就不讨论了)

3.我们还可以通过docker另外的增加网卡的办法来解决:

使用docker network connect给容器增加一块新的网卡

可以看到我们通过docker network connect 这个命令给容器添加网卡eth1,并让这个网卡使用另外的bridge,现在不同bridge之间的容器建可以进行通信

容器间的通信方式其实有三种:

1.IP通信:

上面我们讨论的相同bridge的容器间的通信与不同的bridge之间的通过docker network connect增加网卡使容器间通信,都属于基于IP方式的通信

2.docker dns server:

我们在部署应用之前可能无法确定IP,部署之后在指定IP可能比较麻烦,docker 自带的DNS 服务可以解决这个问题

docker 从1.10版本开始,docker daemon实现了一个内嵌的DNS server,使容器可以直接通过容器名进行通信,

方法也很简单,只要在运行容器的时候通过--name指定容器名,就可以了

运行了两个容器名字为name1和name2,为什么我用name2去pingname1时,不能ping通呢?

因为,这个DNS server通信的方式只适用于user-defined的网络

试验结果为:确实是需要user-defined的网络,才能实现dns server的通信方式

但是不同bridge之间的容器通过DNS的通信方式还是不能实现

3.joined通信方式

joined容器非常特别,它可以使两个或两个以上的容器共享一个网络栈,共享网卡和配置信息,joined容器可以使容器之间可以通过127.0.0.1直接进行通信

通过--nemwork=container:name5的方式将一个新建的容器加入另外一个容器后,两个容器间就有了相同的mac和ip,他们共享了相同的网络栈

name5可以直接通过127.0.0.1直接访问新建httpd容器的http服务

joined通信方式非常适合一下场景:

1.不同容器的程序希望通过loopback高效快速通信,比如web server与app server

2.希望监控其他容器的流量,比如运行在独立的容器中的网络监控程序

centos7下安装docker(12.3容器之间的连通性)的更多相关文章

  1. centos7下安装docker(19容器架构)

    What,Why,How What:什么是容器? 说起容器大家想到的是什么?      集装箱(container),虚拟机,docker,k8s 1. 没毛病,因为容器与集装箱的英文都可以翻译成co ...

  2. centos7下安装docker(11容器操作总结)

    这段时间主要是学习了对容器的操作,包括:容器的状态:start,stop,restart,rename,pause,unpause,rm,attach,exec,kill,logs:还学习了对容器的资 ...

  3. centos7下安装docker(10容器底层--cgroup和namespace)

    cgroup和namespace是实现容器底层的重要技术 cgroup:实现资源限制 namespace:实现资源隔离 1.cgroup:control group Linux操作系统通过cgroup ...

  4. centos7下安装docker(9容器对资源的使用限制-内存)

                  一个docker Host上面会运行若干容器,每个容器都需要CPU,内存和IO资源.容器提供了控制分配多少CPU,内存给每个容器的机制,避免摸个容器因占用太多资源而影响其他 ...

  5. CentOS7下安装docker(Docker系列1)

    CentOS7下安装docker 系统要求 为了安装docker,需要准备 64-bit的CentOS 7 删除非官方的Docker包 yum的仓库中有一个很旧的Docker包, 现在Docker官方 ...

  6. docker(一) Centos7下安装docker

    docker(一) Centos7下安装dockerdocker(二) windows10下安装dockerdocker(三) 镜像和容器常用命令 docker(四) 使用Dockerfile构建镜像 ...

  7. centos7下安装docker与镜像加速

    1.背景 centos7下安装docker 2.安装 第一步:检查是否为centos7版本 第二步:依赖环境安装 执行如下两个命令: yum -y install gcc yum -y install ...

  8. centos7 下安装docker报错:You could try using...

    搞了台VPS,想要装docker,发现死活装不上,各种报错.之前系统是centos6,发现官方现在已经不支持centos6了,遂升级到centos7,然后还是出现下面这个错误. Error: Pack ...

  9. centos7下安装docker(12.5容器在单个host上的网络总结)

    单个host上的容器的网络:通过本章的学习,我们知道docker默认有三种网络,可以通过docker network ls查看: none:封闭的网络,通过--network=none来指定: hos ...

随机推荐

  1. SpringMVC教程2

    接上篇文章-SpringMVC教程1 五.基本操作 1.响应请求的方式 1.1ModeAndView /** * 查询方法 * @return */ @RequestMapping("/qu ...

  2. Java中的静态变量、静态方法问题

    由关键字static所定义的变量与方法,分别称为静态变量和静态方法,它们又都被称为静态成员 1.静态方法 无需本类的对象也可以调用此方法,调用形式为“类名.方法名”,静态方法常常为其他类提供一些方法而 ...

  3. 数据分析之numpy模块

    numpy(numerical python)是python语言的一个扩展程序库,支持大量的维度数组和矩阵运算,此外也针对数组提供大量的数学函数库. 一.创建数组 1 使用array()创建 impo ...

  4. Vim 多行剪切、复制和删除

    剪切 快捷键方式: dd:剪切光标所处当前行 n + dd:剪切光标所在行及以下共 n 行 按 p 粘贴在光标所在行 命令行方式: 例如剪切1到10行,并粘贴在12行处: 1,10 m 12 复制 快 ...

  5. Python使用@property装饰类方法

    Python版本:3.5.2 假如我们有一个Student类,并在其中定义了一个score属性,但是score属性会被显露出去,没办法检查参数,导致成绩可以随意更改: stu = Student() ...

  6. 探秘小程序(10):分享功能+webview

    场景: 小程序页面用webview嵌入了h5页面,h5页面需要与小程序进行交互,h5页面内容不同,分享的链接也不一样 分享功能: 小程序的分享功能即用户点击小程序右上角,转发功能页面.可以指定分享卡片 ...

  7. Net 如何计算一段代码的效率

    在.Net 4.0以后的版本,提供了一个类,该类在 System.Diagnostics命名空间下,使用该类就可以计算出执行结果相同的两端代码的效率,在代码优化上是很实用的. 泛型效率是高是低呢??我 ...

  8. JavaScript类继承

    和其他功能一样,ECMAScript 实现继承的方式不止一种.这是因为 JavaScript 中的继承机制并不是明确规定的,而是通过模仿实现的.这意味着所有的继承细节并非完全由解释程序处理.作为开发者 ...

  9. 【原】Dubbo 多版本号过渡

    之前发过一篇因为接口规范的问题导致其它端出现服务不可用的文章(http://www.cnblogs.com/zdd-java/p/8612763.html),然而最近在查阅了dubbo官方指南文档才知 ...

  10. Archlinux/Manjaro使用笔记-安装配置搜狗输入法步骤

    我的邮箱地址:zytrenren@163.com欢迎大家交流学习纠错! 一.安装qtwebkit-bin软件包解决qtwebkit无法编译安装问题 aurman -S qtwebkit-bin 二.安 ...