Docker多主机网络通信详解
Docker多主机网络通信详解
作者:chszs,未经博主允许不得转载。经许可的转载需注明作者和博客主页:http://blog.csdn.net/chszs
Docker支持多主机网络通信功能,可以通过命令行建立多主机通信网络。本文使用Docker machine和Consul服务发现工具来讲解这一点。
前提是需要先安装Docker工具箱。
1、Docker Multi-Host Networking
作为一个示例,我们会在VirtualBox虚拟机上使用docker machine创建3个Docker主机。其中一个Docker主机运行Consul服务发现工具,另外两个Docker主机则通过第一台主机的Consul服务发现容器共享网络信息。
Docker容器网络部分的相信信息可查看:
https://docs.docker.com/engine/userguide/networking/dockernetworks/
Consul的详细信息见: https://www.consul.io/
Consul的特性:
1)服务发现
Consul使得服务注册和服务发现变得很简单
2)故障检测
支持对服务的健康检查,防止请求被路由到服务不可用的主机上
3)支持多数据中心
Consul支持多数据中心,无需复杂的配置
4)键值存储
Consul使用了键值存储来支持动态配置等
2、设置多主机网络
1)创建名为“host1-Consul”的Docker主机
docker-machine create -d virtualbox host1-Consul
2)在“host1-Consul”主机上运行Consul容器
docker $(docker-machine config host1-Consul) run -d -p "8500:8500" -h "Consul" progrium/Consul -server -bootstrap
3)验证上述容器的运行状态
docker $(docker-machine config host1-Consul) ps
4)运行第二个Docker主机,并注册到前面的Consul容器
docker-machine create -d virtualbox --engine-opt="cluster-store=Consul://$(docker-machine ip host1-Consul):8500" --engine-opt="cluster-advertise=eth1:0" host2
5)运行第三个Docker主机
docker-machine create -d virtualbox --engine-opt="cluster-store=Consul://$(docker-machine ip host1-Consul):8500" --engine-opt="cluster-advertise=eth1:0" host3
现在,后面两个Docker主机都有默认的网络配置,且只能用于单个主机的通信。
6)要实现多主机网络通信,还需要在主机2上创建一个覆盖网络
docker $(docker-machine config host2) network create -d overlay myapp
7)OK,此时如果在主机3上检查网络,就可以看到主机2上创建的覆盖网络。这是因为主机2和3都注册到Consul,网络信息在所有已注册的主机之间实现了共享。
docker $(docker-machine config host2) network ls docker $(docker-machine config host3) network ls
如果是在不同的主机上运行容器,可能就需要使用容器名来连接它们。我们可以这样做个测试。
在主机2上运行一个Nginx容器,在主机3上运行一个busybox容器,通过busybox容器下载Nginx容器默认页面来测试连接是否正常。
8)在主机2上运行Nginx容器,并指定创建的“myapp”网络
docker $(docker-machine config host2) run -itd --name=webfront --net=myapp nginx
9)验证Nginx容器的运行
docker $(docker-machine config host2) ps
10)在主机3上运行一个busybox容器,使用参数下载主机2的Nginx容器的默认主页。
docker $(docker-machine config host3) run -it --rm --net=myapp busybox wget -qO- http://webfront
如果结果返回的是HTML内容的输出,意味着容器能够使用之前创建的覆盖网络连接到主机。

低调大师中文资讯倾力打造互联网数据资讯、行业资源、电子商务、移动互联网、网络营销平台。
持续更新报道IT业界、互联网、市场资讯、驱动更新,是最及时权威的产业资讯及硬件资讯报道平台。
转载内容版权归作者及来源网站所有,本站原创内容转载请注明来源。
- 上一篇
基于Docker的Golang开发
版权声明:本文为博主chszs的原创文章,未经博主允许不得转载。 https://blog.csdn.net/chszs/article/details/50651258 基于Docker的Golang开发 作者:chszs,未经博主允许不得转载。经许可的转载需注明作者和博客主页:http://blog.csdn.net/chszs 一、Docker用于开发 Docker不仅用于部署,它还可以用于开发。 1、为什么要在开发中使用Docker 主要有以下几个原因。 1)一致的开发环境 使用Docker,可以保证整个研发团队使用一致的开发环境。 2)开发环境与最终的生产环境保持一致 这减少了部署出错的可能性。 3)简化了编译和构建的复杂性 对于一些动辄数小时的编译和构建工作,可以用Docker来简化。 4)在开发时只需Docker 无需在自己的开发主机上搭建各种编程语言环境。 5)可以使用同一编程语言的多个版本 可以使用同一编程语言(如python, python, ruby, ruby, java, node)等的多个版本,无需解决多版本冲突的问题。 6)部署很简单 应用程序在容器中运行...
- 下一篇
Docker —— 用于统一开发和部署的轻量级 Linux 容器【转】
转自:http://www.oschina.net/translate/docker-lightweight-linux-containers-consistent-development-and-deployment 英文原文:Docker: Lightweight Linux Containers for Consistent Development and Deployment 使用Docker容器——轻量灵活的VM同类,来接管“依赖地狱”。学习Docker是如何基于LXC技术,通过把应用包装在容器里来使应用具有移植性和独立性。 想象一下可以轻松地把应用和它的依赖打包,然后在其他的开发、测试和生产环境上平滑的运行。这就是开源Docker项目的目标。尽管它现在还没正式到生产阶段,最新的发布(本篇文章编写时是0.7.x)使得Docker实现这一伟大目标又近了一步。 Ley翻译于 2年前 2人顶 顶翻译的不错哦! Docker容器试图解决“依赖地狱”问题。现代的应用通常从已存在的组件组合而来,并且依赖其他服务和应用。比如,你的Python应用可能使用Postgre所为一个数据存储,用...
相关文章
文章评论
共有0条评论来说两句吧...