Docker容器的跨主机连接
Docker容器的跨主机连接
Docker容器的跨主机连接
使用网桥实现跨主机容器连接
网络拓扑
网络连接使用的是Bridge
操作
- 修改
/etc/network/interfaces文件,分配静态IP地址
1.auto br0
2.iface br0 inet static
3.address 10.211.55.3
4.netmask 255.255.255.0
5.gateway 10.211.55.1
6.bridge_ports eth0
- 修改
/etc/default/docker文件,限定分配IP地址段,防止冲突
1.-b 指定使用自定义网桥
2. -b=br0
3.--fixed-cidr 限制ip地址分配范围
4. IP地址划分:
5. Host1:10.211.55.64/26
6. 地址范围:10.211.55.65~10.211.55.126
7. Host2:192.168.59.128/26
8. 地址范围:10.211.55.129~10.211.55.190
优点:
- 配置简单,不依赖第三方软件
缺点: - 与主机在同网段,需要小心划分IP地址
- 需要有网段控制权,在生产环境中不易实现
- 不易管理
- 兼容性不佳
使用Open vSwitch实现跨主机容器连接
Open vSwitch是什么?
Open vSwitch是一个高质量的、多层虚拟交换机,使用开源Apache2.0许可协议,由Nicira Networks开发,主要实现代码为可移植的C代码。它的目的是让大规模网络自动化可以通过编程扩展,同时仍然支持标准的管理接口和协议(例如NetFlow,sFlow,SPAN,RSPAN,CLI,LACP,802.1ag)
原理:
什么是GRE隧道?
GRE:通用路由协议封装
隧道技术(Tunneling)是一种通过使用互联网络的基础设施在网络之间传递数据的方式。使用隧道传递的数据(或负载)可以是不同协议的数据帧或包。隧道协议将其它协议的数据帧或包重新封装然后通过隧道发送。新的帧头提供路由信息,以便通过互联网传递被封装的负载数据。(点对点的再封装技术)
网络连接使用双网卡,Host-Only & NAT
操作
- 建立ovs网桥
查看ovs版本
1.sudo ovs-vsctl show
建立一个名为obr0的网桥
1.sudo ovs-vsctl add-br obr0
- 添加gre连接,接口名为gre0
1.sudo ovs-vsctl add-port obr0 gre0
为接口设置类型和远程另一台主机的地址192.168.59.104
1.sudo ovs-vsctl set interface gre0 type=gre options:remote_ip=192.168.59.104
- 配置docker容器虚拟网桥
1.sudo ifconfig br0 192.168.1.1 netmask 255.255.255.0
- 为虚拟网桥添加ovs接口
1.sudo brctl addif br0 obr0
修改/etc/default/docker,用新建的网桥来代替默认的docker0
1.DOCKER_OPTS="-b=br0"
重启服务sudo service docker restart
- 添加不同Docker容器网段路由
1.sudo ip route add 192.168.2.0/24 via 192.168.59.104 dev eth0
使用weave实现跨主机容器连接
weave是什么?
语义:编织
建立一个虚拟的网络,用于将运行在不同主机的Docker容器连接起来
http://weave.works
https://github.com/weaveworks/weave#readme
网络连接使用双网卡,Host-Only & NAT
操作
- 安装weave
下载
1.sudo wget -O /usr/bin/weave https://raw.githubusercontent.com/zettio/weave/master/weave
更改weave文件夹的权限
1.sudo chmod a+x /usr/bin/weave
- 启动weave
1.weave launch
在启动weave时,实际上是在docker中运行一个weave的容器
- 连接不同主机
为了是两个docker主机能够正确的连接到一起,在运行weave的时候传入另一主机的IP
1.weave launch 192.168.59.103
- 通过weave启动容器
通过weave创建一个容器,返回容器的id
1.c2=$(weave run 192.168.1.2/24 -it ubuntu /bin/bash)
查看id
1.echo $c2
进入容器
1.docker attach $c2
或者直接
1.weave run 192.168.1.2/24 -it --name wc1 ubuntu /bin/bash
Docker容器的跨主机连接的更多相关文章
- Docker学习(15) Docker容器的跨主机连接
Docker容器的跨主机连接 Docker使用网桥跨主机容器连接 Docker使用Open cSwitch实现跨主机容器连接 Docker使用weave实现跨主机容器连接
- Docker 容器的跨主机连接
使用网桥实现跨主枳容器连接 不推荐 使用OpenvSwitch实现跨主机容器连接 OpenvSwitch: OpenvSwitch是一个高质量的.多层虚拟交换枳,使用开源Apache2.0许可协议,由 ...
- 利用虚拟网桥实现Docker容器的跨主机访问
最近在研究Docker,Docker的网络配置是比较令人头疼的部分,尤其是跨主机的容器间通信,很多解决方案都比较复杂,这里,我只用虚拟网桥来实现Docker的跨主机访问,分享出来,希望对Docker学 ...
- docker swarm模式跨主机连接
一.前言 当我们开发好微服务之后,考虑到灵活快速持续部署的需要,通常会考虑将其Docker镜像化并在Docker环境下运行.由于微服务个数通常会较多,把所有微服务部署在一台docker主机上是不现实的 ...
- docker容器间跨主机通信
http://jnzg905.iteye.com/blog/2269583 https://blog.csdn.net/pingpangbing0902/article/details/7823889 ...
- docker实现跨主机连接
实验环境: centos7系统 host1:192.168.42.128 host2:192.168.42.129 dokcer容器跨主机连接 1.使用网桥实现跨主机容器连接 2.使用Open vSw ...
- Docker的跨主机连接:
1使用网桥实现跨主机容器连接. 2使用open vswitch虚礼的交换机实现跨主机容器连接. 3使用weave开源项目工具实现跨主机连接. 使用网桥实现跨主机容器连接:在同一个docker的主机中d ...
- 从Docker容器内部,如何连接到本机的本地主机?
原文 从Docker容器内部,如何连接到本机的本地主机? 编辑:如果您使用的是Docker-for-mac或Docker-for-Windows 18.03+,只需使用主机连接到您的mysql服务即可 ...
- Docker容器的使用和连接
在上一篇文章<Docker从安装部署到Hello World>介绍了如何在CentOS7上安装Docker.这篇文章主要介绍一下Docker容器的使用和连接. vDocker 容器使用 1 ...
随机推荐
- MatLab实现FFT与功率谱
FFT和功率谱估计 用Fourier变换求取信号的功率谱---周期图法 clf; Fs=1000; N=256;Nfft=256;%数据的长度和FFT所用的数据长度 n=0:N-1;t=n/Fs;%采 ...
- PropertyGrid—为复杂属性提供下拉式编辑框和弹出式编辑框
零.引言 PropertyGrid中我们经常看到一些下拉式的编辑方式(Color属性)和弹出式编辑框(字体),这些都是为一些复杂的属性提供的编辑方式,本文主要说明如何实现这样的编辑方式. 一.为属性提 ...
- c# 校验文本框的正则
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 #region ...
- 使用CSS3 Media Queries实现网页自适应(转)
当今银屏分辨率从 320px (iPhone)到 2560px (大屏显示器)或者更大.人们也不再仅仅用台式机来浏览网页,现在有手机,平板电脑等等.所以传统的固定宽度设计形式将不再是个最佳选择,网页设 ...
- css中关于transform、transition、animate的区别
写动画经常会用到这几个属性,他们之间有什么区别呢? 1.transform 每每演示transform属性的,看起来好像都是带动画.这使得小部分直觉化思维的人(包括我)认为transform属性是动画 ...
- 08JS高级 ——“继承”
<!DOCTYPE html> <html xmlns="http://www.w3.org/1999/xhtml"> <head> <m ...
- C#高效分页代码(不用存储过程)
首先创建一张表(要求ID自动编号): create table redheadedfile ( id ,), filenames ), senduser ), primary key(id) ) 然后 ...
- 《高性能JavaScript》的新征程
已经学了<JavaScript语言精粹>,现在学高性能. JS的出现是为了改善网页用户体验的,随着互联网通信速度的改善.计算机性能的提升,web越发丰富:但一段时间内,JS的引擎变化不大. ...
- python正则表达式练习篇
练习一: 利用who命令输出所有已经登录系统的用户的信息,并把登录名.用户登录时的电传.登录时间.登录地址利用正则表达式分割开来. 数据的格式: %who wesc console Jun 20 20 ...
- imagemagick 图像处理扩展
做图像处理的一个工具. http://www.imagemagick.org/script/command-line-processing.php 支持命令行模式,支持接口调用.php 等等都可以,看 ...