实验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的连通性。
- 使用Mininet搭建的SDN拓扑,如下图所示,要求支持OpenFlow 1.3协议,主机名、交换机名以及端口对应正确。
- 通过命令行终端输入“ovs-ofctl”命令,直接在s1和s2上添加流表,划分出所要求的VLAN。
- 主机连通性要求:
- h1 – h3互通
- h2 – h4互通
- 其余主机不通
四、实验心得
这次的实验相较于第一次的实验感觉难度上升了,有的命令还不是很理解,只能在每一次的测试中慢慢摸索命令的含义,这次的实验又收获到许多新知识。刚开始使用时,没有勾选start CLI和OpenFlow1.3,导致代码执行错误,最后经过排查发现了这个问题并解决。在连接拓扑图的时候,由于连线的顺序有误,导致实验做到最后一直失败,没能得到想要的结果,在同学的提醒下,重新将拓扑图进行重连,得到了想要的结果。在抓包的时候,没有使用sudo wireshark,提示我权限不够,无法抓包,最后同学告诉我使用sudo wireshark,最后成功实现抓包。这次实验虽然说难度比较大,但是从中收获到了许多的使用方法和操作命令,希望在之后的学习中,逐渐增强自己的能力,完成每一次的任务。