当前位置: 首页 > news >正文

虚拟化逻辑架构:OVS 交换机与端口管理

目录

一、实验

1.OVS 交换机管理

2.OVS端口管理

二、问题

1.KVM下的br0和virbr0有何区别

2.OVS 虚拟交换机 与接口如何实现关联的创建和删除

3.两个ovs之间如何进行流量交互

4.虚拟网络如何和物理网络互联


一、实验

1.OVS 交换机管理

(1)查看网络信息

lo:本地回环接口

enp0s17 :  ubuntu系统识别到的物理网卡

virbr0/br1/virbr0-nic : linux bridge 网桥相关

root:~# ip add show
1: lo: <LOOPBACK,UP,LOWER_UP> mtu 65536 qdisc noqueue state UNKNOWN group default qlen 1000link/loopback 00:00:00:00:00:00 brd 00:00:00:00:00:00inet 127.0.0.1/8 scope host lovalid_lft forever preferred_lft foreverinet6 ::1/128 scope host valid_lft forever preferred_lft forever
2: enp0s17: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc fq_codel state UP group default qlen 1000link/ether 08:00:27:d8:2a:24 brd ff:ff:ff:ff:ff:ffinet 192.168.31.20/24 brd 192.168.31.255 scope global dynamic noprefixroute enp0s17valid_lft 42599sec preferred_lft 42599secinet6 fe80::f79a:6227:76ba:e22e/64 scope link noprefixroute valid_lft forever preferred_lft forever
3: br1: <NO-CARRIER,BROADCAST,MULTICAST,UP> mtu 1500 qdisc noqueue state DOWN group default qlen 1000link/ether 3a:e1:3f:67:ea:22 brd ff:ff:ff:ff:ff:ff
4: virbr0: <NO-CARRIER,BROADCAST,MULTICAST,UP> mtu 1500 qdisc noqueue state DOWN group default qlen 1000link/ether 52:54:00:2f:20:d6 brd ff:ff:ff:ff:ff:ffinet 192.168.122.1/24 brd 192.168.122.255 scope global virbr0valid_lft forever preferred_lft forever
5: virbr0-nic: <BROADCAST,MULTICAST> mtu 1500 qdisc fq_codel master virbr0 state DOWN group default qlen 1000link/ether 52:54:00:2f:20:d6 brd ff:ff:ff:ff:ff:ff

(2)安装 openvswitch-switch

sudo apt-get install openvswitch-switch

(3)查看软件ID与软件版本

root:/# sudo ovs-vsctl show
e436b05b-210c-468a-9d94-fd63c6c419edovs_version: "2.9.8"

(4)创建OVS 虚拟交换机

ovs-vsctl add-br br0

(5)查看openvswitch

root:/# sudo ovs-vsctl show
e436b05b-210c-468a-9d94-fd63c6c419edBridge "br0"Port "br0"Interface "br0"type: internalovs_version: "2.9.8"

(6)删除OVS 虚拟交换机并查看

ovs-vsctl del-br br0

(7)再次查看openvswitch。显示已删除

root:/# sudo ovs-vsctl show
e436b05b-210c-468a-9d94-fd63c6c419edovs_version: "2.9.8"

2.OVS端口管理

 (1)向br0 中添加 if01端口,并且绑定 if01接口,设置端口类型 internal类型

ovs-vsctl add-port br0 if01 -- set interface if01 type=internal

(2)将if01端口设置为access VLAN模式

ovs-vsctl set port if01 VLAN_mode=access 

(3)查看openvswitch

root:/# sudo ovs-vsctl show
e436b05b-210c-468a-9d94-fd63c6c419edBridge "br0"Port "if01"Interface "if01"type: internalPort "br0"Interface "br0"type: internalovs_version: "2.9.8"

(4)查看网络信息

已新增br0和if01

root:/# ip addr show
1: lo: <LOOPBACK,UP,LOWER_UP> mtu 65536 qdisc noqueue state UNKNOWN group default qlen 1000link/loopback 00:00:00:00:00:00 brd 00:00:00:00:00:00inet 127.0.0.1/8 scope host lovalid_lft forever preferred_lft foreverinet6 ::1/128 scope host valid_lft forever preferred_lft forever
2: enp0s17: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc fq_codel state UP group default qlen 1000link/ether 08:00:27:d8:2a:24 brd ff:ff:ff:ff:ff:ffinet 192.168.31.20/24 brd 192.168.31.255 scope global dynamic noprefixroute enp0s17valid_lft 39205sec preferred_lft 39205secinet6 fe80::f79a:6227:76ba:e22e/64 scope link noprefixroute valid_lft forever preferred_lft forever
3: br1: <NO-CARRIER,BROADCAST,MULTICAST,UP> mtu 1500 qdisc noqueue state DOWN group default qlen 1000link/ether 3a:e1:3f:67:ea:22 brd ff:ff:ff:ff:ff:ff
4: virbr0: <NO-CARRIER,BROADCAST,MULTICAST,UP> mtu 1500 qdisc noqueue state DOWN group default qlen 1000link/ether 52:54:00:2f:20:d6 brd ff:ff:ff:ff:ff:ffinet 192.168.122.1/24 brd 192.168.122.255 scope global virbr0valid_lft forever preferred_lft forever
5: virbr0-nic: <BROADCAST,MULTICAST> mtu 1500 qdisc fq_codel master virbr0 state DOWN group default qlen 1000link/ether 52:54:00:2f:20:d6 brd ff:ff:ff:ff:ff:ff
8: ovs-system: <BROADCAST,MULTICAST> mtu 1500 qdisc noop state DOWN group default qlen 1000link/ether 3a:6f:7f:57:9f:3d brd ff:ff:ff:ff:ff:ff
9: br0: <BROADCAST,MULTICAST> mtu 1500 qdisc noop state DOWN group default qlen 1000link/ether ae:f5:0b:f1:b4:4c brd ff:ff:ff:ff:ff:ff
10: if01: <BROADCAST,MULTICAST> mtu 1500 qdisc noop state DOWN group default qlen 1000link/ether 96:1e:9c:4d:4d:62 brd ff:ff:ff:ff:ff:ff

(5)向br0 中添加 if02端口,并且绑定 if02接口,设置端口类型 internal类型

ovs-vsctl add-port br0 if02 -- set interface if02 type=internal

(6)查看openvswitch

root:/# sudo ovs-vsctl show
e436b05b-210c-468a-9d94-fd63c6c419edBridge "br0"Port "if02"Interface "if02"type: internalPort "if01"Interface "if01"type: internalPort "br0"Interface "br0"type: internalovs_version: "2.9.8"

(7) 查看网络信息

root:/# ip addr show
1: lo: <LOOPBACK,UP,LOWER_UP> mtu 65536 qdisc noqueue state UNKNOWN group default qlen 1000link/loopback 00:00:00:00:00:00 brd 00:00:00:00:00:00inet 127.0.0.1/8 scope host lovalid_lft forever preferred_lft foreverinet6 ::1/128 scope host valid_lft forever preferred_lft forever
2: enp0s17: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc fq_codel state UP group default qlen 1000link/ether 08:00:27:d8:2a:24 brd ff:ff:ff:ff:ff:ffinet 192.168.31.20/24 brd 192.168.31.255 scope global dynamic noprefixroute enp0s17valid_lft 39017sec preferred_lft 39017secinet6 fe80::f79a:6227:76ba:e22e/64 scope link noprefixroute valid_lft forever preferred_lft forever
3: br1: <NO-CARRIER,BROADCAST,MULTICAST,UP> mtu 1500 qdisc noqueue state DOWN group default qlen 1000link/ether 3a:e1:3f:67:ea:22 brd ff:ff:ff:ff:ff:ff
4: virbr0: <NO-CARRIER,BROADCAST,MULTICAST,UP> mtu 1500 qdisc noqueue state DOWN group default qlen 1000link/ether 52:54:00:2f:20:d6 brd ff:ff:ff:ff:ff:ffinet 192.168.122.1/24 brd 192.168.122.255 scope global virbr0valid_lft forever preferred_lft forever
5: virbr0-nic: <BROADCAST,MULTICAST> mtu 1500 qdisc fq_codel master virbr0 state DOWN group default qlen 1000link/ether 52:54:00:2f:20:d6 brd ff:ff:ff:ff:ff:ff
8: ovs-system: <BROADCAST,MULTICAST> mtu 1500 qdisc noop state DOWN group default qlen 1000link/ether 3a:6f:7f:57:9f:3d brd ff:ff:ff:ff:ff:ff
9: br0: <BROADCAST,MULTICAST> mtu 1500 qdisc noop state DOWN group default qlen 1000link/ether ae:f5:0b:f1:b4:4c brd ff:ff:ff:ff:ff:ff
10: if01: <BROADCAST,MULTICAST> mtu 1500 qdisc noop state DOWN group default qlen 1000link/ether 96:1e:9c:4d:4d:62 brd ff:ff:ff:ff:ff:ff
11: if02: <BROADCAST,MULTICAST> mtu 1500 qdisc noop state DOWN group default qlen 1000link/ether 66:c9:a7:75:d2:d8 brd ff:ff:ff:ff:ff:ff

(8)删除名称为 br0的 ovs的if01端口

 ovs-vsctl del-port br0 if01

(9)查看openvswitch

root:/# sudo ovs-vsctl show
e436b05b-210c-468a-9d94-fd63c6c419edBridge "br0"Port "if02"Interface "if02"type: internalPort "br0"Interface "br0"type: internalovs_version: "2.9.8"

(10)查看br0桥-OVS上的所有添加的port端口

root:/# ovs-vsctl list-ports br0
if02

(11)查看网络信息
显示端口if01已删除

root:/# ip addr show
1: lo: <LOOPBACK,UP,LOWER_UP> mtu 65536 qdisc noqueue state UNKNOWN group default qlen 1000link/loopback 00:00:00:00:00:00 brd 00:00:00:00:00:00inet 127.0.0.1/8 scope host lovalid_lft forever preferred_lft foreverinet6 ::1/128 scope host valid_lft forever preferred_lft forever
2: enp0s17: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc fq_codel state UP group default qlen 1000link/ether 08:00:27:d8:2a:24 brd ff:ff:ff:ff:ff:ffinet 192.168.31.20/24 brd 192.168.31.255 scope global dynamic noprefixroute enp0s17valid_lft 38737sec preferred_lft 38737secinet6 fe80::f79a:6227:76ba:e22e/64 scope link noprefixroute valid_lft forever preferred_lft forever
3: br1: <NO-CARRIER,BROADCAST,MULTICAST,UP> mtu 1500 qdisc noqueue state DOWN group default qlen 1000link/ether 3a:e1:3f:67:ea:22 brd ff:ff:ff:ff:ff:ff
4: virbr0: <NO-CARRIER,BROADCAST,MULTICAST,UP> mtu 1500 qdisc noqueue state DOWN group default qlen 1000link/ether 52:54:00:2f:20:d6 brd ff:ff:ff:ff:ff:ffinet 192.168.122.1/24 brd 192.168.122.255 scope global virbr0valid_lft forever preferred_lft forever
5: virbr0-nic: <BROADCAST,MULTICAST> mtu 1500 qdisc fq_codel master virbr0 state DOWN group default qlen 1000link/ether 52:54:00:2f:20:d6 brd ff:ff:ff:ff:ff:ff
8: ovs-system: <BROADCAST,MULTICAST> mtu 1500 qdisc noop state DOWN group default qlen 1000link/ether 3a:6f:7f:57:9f:3d brd ff:ff:ff:ff:ff:ff
9: br0: <BROADCAST,MULTICAST> mtu 1500 qdisc noop state DOWN group default qlen 1000link/ether ae:f5:0b:f1:b4:4c brd ff:ff:ff:ff:ff:ff
11: if02: <BROADCAST,MULTICAST> mtu 1500 qdisc noop state DOWN group default qlen 1000link/ether 66:c9:a7:75:d2:d8 brd ff:ff:ff:ff:ff:ff

(12)删除名称为 br0的 ovs的if02端口

 ovs-vsctl del-port br0 if02

(13)查看openvswitch

root:/# sudo ovs-vsctl show
e436b05b-210c-468a-9d94-fd63c6c419edBridge "br0"Port "br0"Interface "br0"type: internalovs_version: "2.9.8"

(14)查看网络信息

root:/# ip addr show
1: lo: <LOOPBACK,UP,LOWER_UP> mtu 65536 qdisc noqueue state UNKNOWN group default qlen 1000link/loopback 00:00:00:00:00:00 brd 00:00:00:00:00:00inet 127.0.0.1/8 scope host lovalid_lft forever preferred_lft foreverinet6 ::1/128 scope host valid_lft forever preferred_lft forever
2: enp0s17: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc fq_codel state UP group default qlen 1000link/ether 08:00:27:d8:2a:24 brd ff:ff:ff:ff:ff:ffinet 192.168.31.20/24 brd 192.168.31.255 scope global dynamic noprefixroute enp0s17valid_lft 38698sec preferred_lft 38698secinet6 fe80::f79a:6227:76ba:e22e/64 scope link noprefixroute valid_lft forever preferred_lft forever
3: br1: <NO-CARRIER,BROADCAST,MULTICAST,UP> mtu 1500 qdisc noqueue state DOWN group default qlen 1000link/ether 3a:e1:3f:67:ea:22 brd ff:ff:ff:ff:ff:ff
4: virbr0: <NO-CARRIER,BROADCAST,MULTICAST,UP> mtu 1500 qdisc noqueue state DOWN group default qlen 1000link/ether 52:54:00:2f:20:d6 brd ff:ff:ff:ff:ff:ffinet 192.168.122.1/24 brd 192.168.122.255 scope global virbr0valid_lft forever preferred_lft forever
5: virbr0-nic: <BROADCAST,MULTICAST> mtu 1500 qdisc fq_codel master virbr0 state DOWN group default qlen 1000link/ether 52:54:00:2f:20:d6 brd ff:ff:ff:ff:ff:ff
8: ovs-system: <BROADCAST,MULTICAST> mtu 1500 qdisc noop state DOWN group default qlen 1000link/ether 3a:6f:7f:57:9f:3d brd ff:ff:ff:ff:ff:ff
9: br0: <BROADCAST,MULTICAST> mtu 1500 qdisc noop state DOWN group default qlen 1000link/ether ae:f5:0b:f1:b4:4c brd ff:ff:ff:ff:ff:ff

(15)删除名称为 br0的 ovs

ovs-vsctl del-br br0

(16)查看openvswitch

root:/# sudo ovs-vsctl show
e436b05b-210c-468a-9d94-fd63c6c419edovs_version: "2.9.8"

二、问题

1.KVM下的br0和virbr0有何区别

(1)KVM 的三种网络模式

桥接、仅主机、NAT

(2)区别

默认br0是桥接模式;

virbr0为NAT模式,它其实就是hypervisor的虚拟接口

2.OVS 虚拟交换机 与接口如何实现关联的创建和删除

(1)关联操作

#向br0 – OVS中添加 if01 端口,并且绑定  if01接口  ,设置端口类型 internal类型
ovs-vsctl add-port br0 if01   -- set interface  if01 type=internal#将if01 端口设置为 access VLAN模式
ovs-vsctl set port if01 VLAN_mode=access#查看br0桥-OVS上的所有添加的port端口ovs-vsctl  list-ports br0 # 在ovs – br0 删除掉if01端口 (接口也删除)
ovs-vsctl   del-port  br0 if01#为VM虚拟机配置IP地址
sudo ifconfig eth0 172.16.10.1 netmask 255.255.255.0#查看br0的接口信息
ovs-ofctl show br0#查看br0的MAC地址表(VLAN信息)
ovs-appctl  fdb/show br0# 添加VLAN标记
ovs-vsctl  add port if01  tag 10  #将接口01划分到vlan10
ovs-vsctl  add port if02  tag 20  #将接口02划分到vlan20#删除VLAN标记
ovs-vsctl  remove port if01  tag 10  #将接口01划分到vlan10# 查看OVS数量-名称
ovs-vsctl list-br

3.两个ovs之间如何进行流量交互

(1)设置互联patch

#默认允许所有VLAN通过patch接口互联需要设置peer(对端)
ovs-vsctl add-port br0 patch-br0-br2 -- set interface patch-br0-br2 type=patch options:peer=patch-br2-br0ovs-vsctl add-port br2 patch-br2-br0 -- set interface patch-br2-br0 type=patch options:peer=patch-br0-br2

4.虚拟网络如何和物理网络互联

(1)添加上行链路

#将一个物理网卡作为OVS虚拟交换机的上行链路,一个网卡作为虚拟交换机的上行链路后,该网卡直接作为OVS的一个逻辑接口,衔接物理和虚拟网络
ovs-vsctl add port  br0 enp0s17   #将enp0s17物理网卡绑定到br0虚拟交换机,作为一个ovs中的一个接口ovs-ctl set port enp0s17 VLAN_mode=trunkovs-ctl set port enp0s17 trunk=10,20

http://www.lryc.cn/news/254181.html

相关文章:

  • 【springboot】idea项目启动端口被占用
  • linux环境下编译安装OpenCV For Java(CentOS 7)
  • 健康学习到 150 岁:人体系统调优不完全指南 | 开源日报 No.93
  • C++ Easyx 三子棋
  • [NAND Flash 2.1] NAND Flash 闪存改变了现代生活
  • 2015年五一杯数学建模B题空气污染问题研究解题全过程文档及程序
  • java面试题,上楼梯有多少种方式
  • 8.HTTP工作原理
  • 环境部署的学习笔记(Docker)
  • Navicat在分辨率不同的屏幕窗口显示大小不一致问题解决
  • 通过代码搞明白JAVA中值传递和引用传递
  • ambari 开启hdfs回收站机制
  • 服务器数据恢复—服务器重装系统导致逻辑卷发生改变的数据恢复案例
  • 软件工程之架构设计
  • oracle java.sql.SQLException: Invalid column type: 1111
  • Mac 浏览器下载的文件名总是「乱码」
  • Redis Reactor事件驱动模型源码
  • cv2.error: OpenCV(4.7.0)
  • 10.vue3项目(十):spu管理页面的sku的新增和修改
  • Java LeetCode篇-深入了解二叉树经典解法(三种方式实现:获取二叉树的最大深度)
  • Image Segmentation Using Deep Learning: A Survey
  • 可视化开源编辑器Swagger Editor本地部署并实现远程访问管理编辑文档
  • Java TCP协议实现一对一聊天与UDP协议实现群聊案例
  • 【从0配置JAVA项目相关环境1】jdk + VSCode运行java + mysql + Navicat + 数据库本地化 + 启动java项目
  • 人工智能_机器学习053_支持向量机SVM目标函数推导_SVM条件_公式推导过程---人工智能工作笔记0093
  • 二叉树的前、中和后序遍历的递归与迭代实现
  • 人体姿态估计算法
  • docker部署jupyter
  • 音视频的功耗优化
  • Python实现FA萤火虫优化算法优化XGBoost回归模型(XGBRegressor算法)项目实战