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

一、实验目的

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

下载虚拟机软件Oracle VisualBox 或 VMware;
在虚拟机中安装Ubuntu 20.04 Desktop amd64,并完整安装Mininet;
三、实验要求

(一)基本要求

创建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命令执行结果:

连通性测试:

2.使用Mininet搭建的SDN拓扑,如下图所示,要求支持OpenFlow 1.3协议,主机名、交换机名以及端口对应正确。

创建好如上拓扑后,支持OpenFlow1.3协议,然后将该拓扑保存为py文件,命名为102192107.py。打开该py文件,修改Add links以下代码,修改部分如下:

生成网络拓扑:

3.通过命令行终端输入“ovs-ofctl”命令,直接在s1和s2上添加流表,划分出所要求的VLAN。



4.主机连通性要求:
h1 – h3互通

h2 – h4互通

其余主机不通

h1和h3互通,h2和h4互通,其他主机不互通。
命令行中输入下述指令查看下发流表

使用sudo wireshark运行wireshark,同时mininet使用pingall,令wireshark抓取数据包

对h1和h3发送的包标记为0

对h2和h4发来的包标记为1,符合要求。

四、个人总结

 这次的作业难度明显加大,刚开始做实验的时候遇到了许多问题。有些代码一开始没输错,试了几次才正常运行。在连通性测试那里,程序一直运行,我等了很久才发觉不对劲,问了舍友才知道要输入:ctrl+C。然后程序停止运行,顺利得到截图。后面虚拟空间的创建与配置也是几次出错,百度了一下虚拟空间删除的命令。最后总算顺利进行下去了。

在下发流表那步,因为只读状态,修改无法保存。又是靠着别人的帮助将只读状态去除,然后才得以进行下一步。因为时间关系,我没有做进阶作业。下次我会更加努力,尽全力做好作业。

posted @ 2021-09-22 01:39  无告  阅读(43)  评论(0编辑  收藏  举报