转载请注明出处:点我

由于Docker自身的网络的原因,想要在多主机间的容器之间进行通信是比较麻烦的事情。可以利用Ambassador容器来实现这一功能。

基本原理:

利用Ambassador来实现主机间容器进行通信时,需要在两台需要通信的容器的主机上都启动Ambassador容器。由Ambassador容器提供数据转发服务。

当客户端主机上的容器client_container想要同服务器端主机上的容器server_container通信时,client_container容器直接访问同一台主机上运行的client_ambassador容器,请求会被client_ambassador容器转发出去,达到服务端主机。服务端Ambassador容器server_ambassador监听在对应的端口,收到请求后再转发给服务器容器server_container。

下面是一个示例:

主机A为服务器端,上面运行了一个运行Flask程序的容器server_container,主机B为客户端,上面运行一个容器client_container来访问主机A上面的Flask程序。先来看看主机A上面的启动server_container的image的Dockerfile文件:

 FROM ubuntu
MAINTAINER rio_2607 j_huang@126.com RUN apt-get update
RUN apt-get install -y python-pip
RUN pip install flask ADD app.py /app
WORKDIR /app
EXPOSE 5002
CMD ["python'","app.py"]

从上面的代码可以看到,我们把app.py文件复制到了/app目录下,在把工作目录切换到了/app目录下面,之后开放了5002端口,这一点很重要,开放的端口会影响后面的命令,然后在容器启动的时候会执行app.py文件。现在来看下app.py文件中的代码:

 from flask import Flask

 app = Flask(__name__)

 @app.route('/')
def hello():
return "Hello World" if "__main__" == __name__:
app.run(host="0.0.0.0",port=5002,debug=True)

代码很简单,不用解释。启动容器server_container:

sudo docker run -d --name flask rio_2607/flask

现在在主机A上面启动ambassador容器,并把flask容器link到这个ambassador容器上面去:

sudo docker run -d --name server_ambassador --link flask:flask_f -p 5002:5002 svendowideit/ambassador

上面命令中可以看到flask link后的别名是flask_f,这一点很重要,因为这会影响到server_ambassador的环境变量名字,也就会影响之后的命令。现在进入这个server_ambassador里面看下环境变量:

sudo docker exec -it server_ambassador /bin/sh

进入之后使用env命令可以查看到下面的环境变量当前容器的环境变量:

可以看到环境变量军事以FLASK_F开头的,我们接下来会使用FLASK_F_PORT_5002_TCP这个环境变量。

接下来我们在主机B上面启动ambassador容器,命令如下:

sudo docker run -d --name client_ambassador  --expose 5002 -e FLASK_F_PORT_5002_TCP=tcp://10.31.181.84:5002 svendowideit/ambassador

在上面这条命令中,我们传入了FLASK_F_PORT_TCP这个环境变量,这个变量就是之前使用env命令看到的,这里要把IP地址替换成运行改容器的主机,也就是主机A的IP地址。

接下来我们要启动一个容器client_container来访问主机A上面的Flask程序。这里我们仅仅是启动一个ubuntu容器,安装curl程序,启动容器时,要把之前启动的client_ambassador容器挂接过来。命令如下:

sudo docker run -it --rm --link client_ambassador:am ubuntu /bin/bash

上面的命令中,我们把ambassador挂接到client_container容器中,别名为am。现在,我们已经进入到了这个client_container中,安装curl

apt-get update
apt-get install -y curl

安装完curl之后,使用curl来访问主机A上面的Flask程序,这是通过使用别名am来实现的

curl am:5002

命令执行完成之后,可以看到结果如下:

可以看到curl命令返回了Hello World,表明主机B上面的client_container容器成功的访问到了主机A上面的flask容器。

注意:在使用Ambassador容器实现容器跨主机通信的时候,Ambassador暴露出的端口最好要跟服务器端容器(本文中是flask容器,暴露出5002端口)暴露一致。我在实验的过程中把--expose 5002端口改成了其他的端口,curl命令连接失败,跨主机通信失败,原因暂时还没有查明。

使用Ambassador只能实现一对多的容器跨主机通信,也就是说一台机器A充当服务器,其他的机器统一访问机器A,无法实现多对多的通信。

集群的话可以使用Docker公司的swarm来进行管理,接下来准备研究下swarm。

Docker:使用Ambassador进行跨主机间容器通信的更多相关文章

  1. centos7下安装docker(15.1跨主机网络)

    之前学习了单个host上的网络,我们知道单个host上的网络有:none,host,bridge和joined,他们解决了单个host上面的容器通信的问题:接下来我们讨论跨主机间容器通信的方案 跨主机 ...

  2. [docker]使用quaaga实现(rip ospf)实现主机间容器互通

    使用quaaga实现(rip ospf)实现主机间容器互通 - n1设置 brctl addbr br0 ip a a 10.1.1.1/24 br0 ip a a 10.1.1.1/24 dev b ...

  3. 测试docker不同主机间容器互相访问

    测试服务器(centos6.5):192.168.16.70 网卡:eth0192.168.16.74 网卡:eth0第一步,分别在2台机器执行: yum install docker service ...

  4. centos7下安装docker(15.6docker跨主机网络---Weave)

    Weave是weaveworks开发的容器网络解决方案.weave创建的虚拟网络可以将部署在多个主机上的容器连接起来.对于容器来说,weave就像一个巨大的网络交换机,容器可以直接通信,无需NAT和端 ...

  5. centos7下安装docker(15.4跨主机网络-flannel)

    flannel是CoreOS开发的容器网络解决方案,flannel为每一个host分配一个subnet,容器从这些subnet中分配IP,这些IP可以在host之间路由,容器无需NAT和port ma ...

  6. centos7下安装docker(15.3跨主机网络-macvlan)

    除了ovrlay,docker还开发了另一个支持跨主机容器的driver:macvlan macvlan本身是linu kernel模块,其功能是允许在同一物理网卡上配置多了MAC地址,即:多个int ...

  7. centos7下安装docker(15.2跨主机网络-overlay)

    为支持容器跨主机通信,Docker提供了overlay driver,使用户可以创建基于VxLAN的overlay网络.VxLAN可将二层数据封装到UDP进行传输,VxLAN提供与VLAN相同的以太网 ...

  8. docker swarm 搭建及跨主机网络互连案例分析

    准备工作 安装docker,不建议直接使用Docker官方的yum install docker wget http://yum.dockerproject.org/repo/main/centos/ ...

  9. Docker使用rexray做跨主机存储

    Rex-Ray 是一个优秀的 Docker volume driver,不过只有最新版docker才支持. Rex-Ray 以 standalone 进程的方式运行在 Docker 主机上,安装方法很 ...

随机推荐

  1. 用physdiskwrite在VMware虚拟机上安装m0n0wall【转】

    在一台PC机上安装m0n0wall,相信大家都有经验.一般采用两种方法:1.在一台Windows XP或Windows 2000的PC上,下载physdiskwrite软件和m0n0wall映像文件( ...

  2. 第二个UI脚本--Python+selenium之unittest+HTMLtestRunner及python的继承

    前面有一篇对于常见元素的识别和操作的python自动化脚本,这一篇就接着聊下python的类继承,已经它的第三款unittest框架,和报告收集包HTMLtestRunner的应用. 还是直接上代码吧 ...

  3. LoadRunner error -27498

    URL=http://172.18.20.70:7001/workflow/bjtel/leasedline/ querystat/ subOrderQuery.do错误分析:这种错误常常是因为并发压 ...

  4. [转]Linux的tail 与head 命令

    转自:http://blog.csdn.net/carolzhang8406/article/details/6112707 head命令是用来查看具体文件的前面几行的内容,具体格式如下: head ...

  5. Solaris系统管理(二)资源管理与网络配置

    上一篇主要总结了Solaris安装后需要进行的一些设置,如ssh,pkgutil管理依赖,vim安装. 这一篇将会对Solaris资源管理与网络配置进行总结. 四 Solaris 系统管理 1,查询总 ...

  6. 用ASP.Net写一个发送ICQ信息的程序

    用ASP.Net写一个发送ICQ信息的程序 这里我给大家提供一个很实用的例子,就是在线发送ICQ信息.想一想我们在网页上直接给朋友发送ICQ信息,那是多么美妙的事情啊.呵呵,在吹牛啊,其实ICQ本来就 ...

  7. ASP.NET下跨应用共享Session和使用Redis进行Session托管简介

    在之前的博客中,我说到了Session的共享问题,其中说到了Web Farm和Web Garden两种情况下Session的处理.在ASP.NET提供的Session处理方法中,有以下四种模式: 1. ...

  8. JAVA分析html算法(JAVA网页蜘蛛算法)

    近来有些朋友在做蜘蛛算法,或者在网页上面做深度的数据挖掘.但是遇到复杂而繁琐的html页面大家都望而却步.因为很难获取到相应的数据. 最古老的办法的是尝试用正则表达式,估计那么繁琐的东西得不偿失,浪费 ...

  9. 在C语言环境下使用google protobuf

    本文写给经常使用C编程且不喜欢C++而又要经常使用google protobuf的人.        经常写通讯程序的人对数据进行序列化或者反序列化时,可能经常使用google的protobuf(PB ...

  10. logback打印不出日志

    原因: 1. 可能是jar包不完整 , 基本jar包包括:  logback-access , logback-core , logback-classic , perf4j , slf4j-api ...