Docker(五):Docker高级网络配置
1、容器跨主机多子网方案
网络设计如下:
主机1:10.110.52.38
容器1: 192.168.0.1 vlan1
容器2: 192.168.0.2 vlan2
主机2:10.110.52.66
容器3: 192.168.0.3 vlan1
容器4: 192.168.0.4 vlan2
本示例采用OVS(Open vSwitch)网桥替代Docker默认的Linux网桥,搭建两个跨主机的vlan。实现跨主机的属于同个vlan互通,不同vlan隔离。
2、搭建步骤
Host1的网桥配置:
#创建一个网桥:ovs-vsctl add-br ovs-br0
#创建一个到10.110.52.66的vxlan tunnel:ovs-vsctl add-port ovs-br0 vxlan-10.110.52.66 -- set interface vxlan-10.110.52.66 type=vxlan option:remote_ip="10.110.52.66"
#运行docker:docker run -tid --net=none --name=container1 ubuntu:latest /bin/bash
#获取container1的pid:pid=$(docker inspect -f '{{.State.pid}}' container1)
#创建可以使用ip netns命令操纵network namespace的项
#mkdir -p /var/run/netns
#ln -s /proc/$pid/ns/net /var/run/netns/$pid
#为container1创建一对虚拟网卡接口
#ip link add name vethC1Host mtu 1500 type veth peer namevethC1Container mtu 1500
#将veth pair的一端加入到ovs网桥中,并设置为vlan1,vlan通过tag值划分
#ovs-vsctl add-port ovs-br0 vethC1Host tag=1
#启用:ip link set vethC1Host up
#将veth pair的另一端放入容器所在network namespace
#ip link set vethC1Container netns $pid
#进入$pid所在的netns中,配置刚才放入其中的虚拟网卡,改名为eth0,配置IP并启用
#ip netns exec $pid ip link set dev vethC1Container name eth0
#ip netns exec $pid ip addr add 192.168.0.1/24 dev eth0
#ip netns exec $pid ip link set eth0 up
#container2的网络配置与container1类似
#运行docker:docker run -tid --net=none --name=container2 ubuntu:latest /bin/bash
#获取container1的pid:pid=$(docker inspect -f '{{.State.pid}}' container2)
#mkdir -p /var/run/netns
#ln -s /proc/$pid/ns/net /var/run/netns/$pid
#ip link add name vethC2Host mtu 1500 type veth peer namevethC2Container mtu 1500
#ovs-vsctl add-port ovs-br0 vethC1Host tag=2
#启用:ip link set vethC2Host up
#ip link set vethC2Container netns $pid
#ip netns exec $pid ip link set dev vethC2Container name eth0
#ip netns exec $pid ip addr add 192.168.0.2/24 dev eth0
#ip netns exec $pid ip link set eth0 up
Host2网桥配置:
#创建一个网桥:ovs-vsctl add-br ovs-br0
#创建一个到10.110.52.38的vxlan tunnel:ovs-vsctl add-port ovs-br0 vxlan-10.110.52.38 -- set interface vxlan-10.110.52.38 type=vxlan option:remote_ip="10.110.52.38"
#运行docker:docker run -tid --net=none --name=container3 ubuntu:latest /bin/bash
#获取container3的pid:pid=$(docker inspect -f '{{.State.pid}}' container3)
#mkdir -p /var/run/netns
#ln -s /proc/$pid/ns/net /var/run/netns/$pid
#ip link add name vethC3Host mtu 1500 type veth peer namevethC3Container mtu 1500
#将veth pair的一端加入到ovs网桥中,并设置为vlan3,vlan通过tag值划分
#ovs-vsctl add-port ovs-br0 vethC3Host tag=1
#启用:ip link set vethC3Host up
#将veth pair的另一端放入容器所在network namespace
#ip link set vethC1Container netns $pid
#进入$pid所在的netns中,配置刚才放入其中的虚拟网卡,改名为eth0,配置IP并启用
#ip netns exec $pid ip link set dev vethC3Container name eth0
#ip netns exec $pid ip addr add 192.168.0.3/24 dev eth0
#ip netns exec $pid ip link set eth0 up
#container4的网络配置与container3类似
#运行docker:docker run -tid --net=none --name=container4 ubuntu:latest /bin/bash
#获取container4的pid:pid=$(docker inspect -f '{{.State.pid}}' container4)
#mkdir -p /var/run/netns
#ln -s /proc/$pid/ns/net /var/run/netns/$pid
#ip link add name vethC4Host mtu 1500 type veth peer namevethC4Container mtu 1500
#ovs-vsctl add-port ovs-br0 vethC4Host tag=2
#启用:ip link set vethC4Host up
#ip link set vethC4Container netns $pid
#ip netns exec $pid ip link set dev vethC4Container name eth0
#ip netns exec $pid ip addr add 192.168.0.4/24 dev eth0
#ip netns exec $pid ip link set eth0 up
配置完成以后可以使用ovs-vsctl show命令查看Host1和Host2网桥及网卡信息。
此时相同vlan下的容器可跨网段访问。
Docker(五):Docker高级网络配置的更多相关文章
- Docker Network Configuration 高级网络配置
Network Configuration TL;DR When Docker starts, it creates a virtual interface named docker0 on the ...
- Docker 使用指南 (三)—— 网络配置
版权声明:本文由田飞雨原创文章,转载请注明出处: 文章原文链接:https://www.qcloud.com/community/article/95 来源:腾云阁 https://www.qclou ...
- DOCKER学习_005:Flannel网络配置
一 简介 Flannel是一种基于overlay网络的跨主机容器网络解决方案,也就是将TCP数据包封装在另一种网络包里面进行路由转发和通信, Flannel是CoreOS开发,专门用于docker多机 ...
- Linux安装Tomcat-Nginx-FastDFS-Redis-Solr-集群——【第五集之网络配置】
还有对第五集的补充:https://www.cnblogs.com/lirenhe/p/10405069.html 1,如果不为这个linux系统或者这台虚拟机配置IP,就不能实现通信.这样的之后安装 ...
- (转) docker跨主机 macvlan 网络配置
原文链接 https://github.com/alfredhuang211/study-docker-doc/blob/master/docker%E8%B7%A8%E4%B8%BB%E6%9C%B ...
- Linux系统的高级网络配置(bond、team、网桥)
1.bond接口 Red Hat Enterprise Linux 允许管理员使用 bonding 内核模块和称为通道绑定接口的特殊网络接口将多个网络接口绑定 到一个通道.根据选择的绑定模式 , 通道 ...
- 5、Docker网络配置(单机)
一.概述 以下内容参考:https://docs.docker.com/network/#network-drivers Docker容器和服务如此强大的原因之一是您可以将它们连接在一起,或者将它们连 ...
- 03 . Docker数据资源管理与网络
Docker数据卷 在容器中管理数据主要有两种方式 # 数据卷(Data volumes) # 数据卷容器(Data volume containers) # 数据卷是一个可供一个或多个容器使用的特殊 ...
- Docker的4种网络模式
我们在使用docker run创建Docker容器时,可以用--net选项指定容器的网络模式,Docker有以下4种网络模式: · host模式,使用--net=host指定. · container ...
随机推荐
- Jquery基础知识01
1:$(document).ready()function{}和window.onload()的区别. 1:$(document).ready()function{} 该方法等到Dom结构绘制完毕 ...
- C#Winform设计的通用标签设计器
技术看点 PropertyGrid的使用 自定义控件的使用 对象序列化成XML GDI+Windows驱动打印 前言 是的,一不小心把公司名称透露了.索性帮公司打一下广告.公司(上海易溯信息科技)是中 ...
- UnityShader-菲涅尔反射(Fresnel Reflection)
菲涅耳公式(或菲涅耳方程),由奥古斯丁·让·菲涅耳导出.用来描述光在不同折射率的介质之间的行为.由公式推导出的光的反射称之为"菲涅尔反射".菲涅尔公式是光学中的重要公式,用它能解释 ...
- CCF-201409-2-画图
问题描述 试题编号: 201409-2 试题名称: 画图 时间限制: 1.0s 内存限制: 256.0MB 问题描述: 问题描述 在一个定义了直角坐标系的纸上,画一个(x1,y1)到(x2,y2)的矩 ...
- 一个在 .NET 一线战斗了十年的 C# 程序员的内心独白
这是我的一个内心独白,内容有点长,希望你能耐心地看完. 估计看到标题,大部分人都会说:哇!大牛!膜拜--之类的.至于是不是大牛,那我不知道,毕竟我依然有很多地方不懂,特别是现在已经流行的 Redis ...
- Solr6.5.0配置solrcore图文详解
准备环境: solr6.5.0安装完成 jdk1.8 solrhome配置成功 详情:
- Python的控制语句
1. 控制语句 控制语句是用来改变程序执行的顺序.程序利用控制语句有条件地执行语句,循环地执行语句或者跳转到程序中的其他部分执行语句. Python支持三种不同的控制语句:if,for和while, ...
- 【Win 10 应用开发】MIDI 音乐合成——乐理篇
针对 MIDI 音乐的 API ,其实在 Win 8.1 的时候就出现.在UWP中采用了新的驱动模式,MIDI 消息传递更加高效. 首先得说明的是,UWP 的 MIDI 相关 API 不是针对 MID ...
- 关于SPI通信原理与程序实现
第一次接触SPI是因为当时用到NRF24L01,需要用SPI进行通信.因为2401上面写着MOSI.MISO.SS.RST,当时以为只要用到SPI就肯定有这几个引脚,以至于限制了自己的思维.只认识MI ...
- SOJ--Zig-Zag
Zig-Zag 在图形图像处理中经常须要将一个二维的图像矩阵转化为一维的向量.二维化一维的过程实际上就是将二维数组的元素按某种顺序构成一维数组. 一种经常使用的序列叫"Zig-Zag&quo ...