实验2:Open vSwitch虚拟交换机实践
实验2:Open vSwitch虚拟交换机实践
一、实验目的
1.能够对Open vSwitch进行基本操作;
2.能够通过命令行终端使用OVS命令操作Open vSwitch交换机,管理流表;
3.能够通过Mininet的Python代码运行OVS命令,控制网络拓扑中的Open vSwitch交换机
二、实验环境
1.下载虚拟机软件Oracle VisualBox 或 VMware;
2.在虚拟机中安装Ubuntu 20.04 Desktop amd64,并完整安装Mininet;
三、实验要求
(一)基本要求
1.创建OVS交换机,并以ovs-switchxxx命名,其中xxx为本人在选课班级中的序号,例如ovs-switch001, ovs-switch088等。在创建的交换机上增加端口p0和p1,设置p0的端口号为100,p1的端口号为101,类型均为internal;为了避免网络接口上的地址和本机已有网络地址冲突,需要创建虚拟网络空间(参考命令netns)ns0和ns1,分别将p0和p1移入,并分别配置p0和p1端口的ip地址为190.168.0.100、192.168.0.101,子网掩码为255.255.255.0;最后测试p0和p1的连通性。
ovs-vsctl show命令:
p0和p1连通性测试的执行结果:p0和p1成功连通
2.使用Mininet搭建的SDN拓扑,如下图所示,要求支持OpenFlow 1.3协议,主机名、交换机名以及端口对应正确。
在左上角的 Edit 中选择 Preference,设置支持OpenFlow 1.3。
在左上角的 file 中选择 export level2 script 将文件保存为lab2.py,然后使用addLink创建拓扑连接
在刚刚的文件夹中打开另一个命令行终端(前面一个终端不能关掉),输入 sudo python3 lab2.py 运行代码,查看网络状态。正常。
3.通过命令行终端输入“ovs-ofctl”命令,直接在s1和s2上添加流表,划分出所要求的VLAN。
在终端输入 ovs-ofctl 直接在s1和s2上添加流表,划分出所要求的VLAN。
| VLAN_ID | Hosts |
| -------- | ----- | ----- |
| 0 | h1 h3 | |
| 1 | h2 h4 | |
#给s1添加流表
sudo ovs-ofctl -O OpenFlow13 add-flow s1 priority=1,in_port=1,actions=push_vlan:0x8100,set_field:4096-\>vlan_vid,output:3
sudo ovs-ofctl -O OpenFlow13 add-flow s1 priority=1,in_port=2,actions=push_vlan:0x8100,set_field:4097-\>vlan_vid,output:3
sudo ovs-ofctl -O OpenFlow13 add-flow s1 priority=1,dl_vlan=0,actions=pop_vlan,output:1
sudo ovs-ofctl -O OpenFlow13 add-flow s1 priority=1,dl_vlan=1,actions=pop_vlan,output:2
#给s2添加流表
sudo ovs-ofctl -O OpenFlow13 add-flow s2 priority=1,in_port=1,actions=push_vlan:0x8100,set_field:4096-\>vlan_vid,output:3
sudo ovs-ofctl -O OpenFlow13 add-flow s2 priority=1,in_port=2,actions=push_vlan:0x8100,set_field:4097-\>vlan_vid,output:3
sudo ovs-ofctl -O OpenFlow13 add-flow s2 priority=1,dl_vlan=0,actions=pop_vlan,output:1
sudo ovs-ofctl -O OpenFlow13 add-flow s2 priority=1,dl_vlan=1,actions=pop_vlan,output:2
终端输入 sudo ovs-ofctl -O OpenFlow13 dump-flows s1 和 sudo ovs-ofctl -O OpenFlow13 dump-flows s2 查看流表。
4.主机连通性要求:
h1 – h3互通
h2 – h4互通
其余主机不通
在运行 mininet 的终端输入 pingall 查看连通性。符合连通性要求。
在运行 mininet 的终端输入 pingall,在另一个终端输入 sudo wireshark,选择 s1 的3号端口或 s2 的3号端口。抓包 ID。
四、个人总结
- 这次实验学习了 Open vSwitch 的相关知识,学会创建Open vSwitch 交换机、划分虚拟网络空间、下发流表等操作。
- 用可视化建立拓扑的时候保存文件只保存了.py文件,后续步骤做不出来,重新做了一遍同时保存了.mn文件才能接着做,不知道是什么原因。
- 运行完mininet后就直接关闭了终端,导致后续步骤做不出来,提示“s1 is not a bridge or socket”,后来从网上百度才发现了原因,重新做了一遍,不关闭命令行终端就能解决这个问题。