实验2:Open vSwitch虚拟交换机实践

一、实验目的

能够对Open vSwitch进行基本操作;
能够通过命令行终端使用OVS命令操作Open vSwitch交换机,管理流表;
能够通过Mininet的Python代码运行OVS命令,控制网络拓扑中的Open vSwitch交换机

二、实验环境

下载虚拟机软件Oracle VisualBox 或 VMware;
在虚拟机中安装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的连通性。
第2次上机作业_命令行
第2次上机作业_虚拟网络_02
2.使用Mininet搭建的SDN拓扑,如下图所示,要求支持OpenFlow 1.3协议,主机名、交换机名以及端口对应正确。
3.通过命令行终端输入“ovs-ofctl”命令,直接在s1和s2上添加流表,划分出所要求的VLAN。
4.主机连通性要求:
h1 – h3互通
h2 – h4互通
其余主机不通
第2次上机作业_命令行_03
第2次上机作业_ip地址_04
第2次上机作业_ip地址_05
第2次上机作业_命令行_06
第2次上机作业_ip地址_07
第2次上机作业_端口号_08

四、心得体会

这次得感谢樊同学的帮助,让我完成了此次实验。通过本次实验,我更加了解ovs交换机,包括如何在交换机上增加端口,并将其移入创建好的虚拟网络空间,以及通过sudo ovs-vsctl show可以查看交换机上的端口信息;再者,就是通过ovs-ofctl命令来在s1和s2上添加流表以及划分vlan,最后通过sudo ovs-ofctl dump-flows来查看交换机中的所有流表项;最后,就是通过sudo wireshark可以直接打开wireshark进行抓包。