实验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命令的运行结果截图如下:
- p0和p1连通性测试的执行结果截图如下:
- 使用Mininet搭建的SDN拓扑,如下图所示,要求支持OpenFlow 1.3协议,主机名、交换机名以及端口对应正确。
- 修改相应的端口并测试
- 通过命令行终端输入“ovs-ofctl”命令,直接在s1和s2上添加流表,划分出所要求的VLAN。
VLAN_ID | Hosts |
---|---|
0 | h1 h3 |
1 | h2 h4 |
4. 主机连通性要求:
- h1 – h3互通
- h2 – h4互通
- 其余主机不通
- 利用wireshark抓包,抓取s1的3号端口
- s1向s3发送的包中id为0,s2向s4发送的包中id为1
四、个人总结
- 在这次实验中我学到了有关Open vSwitch的新知识,例如以ovs-switch和ovs-ofctl的命令操作,并且再次回顾了如何使用Mininet搭建SDN拓扑,加深了上次实验的印象。学会了添加流表,划分出所要求的VLAN。
- 总的来说我认为这次实验难度中等,遇到的困难并不太大,通过自学以及向同学请教都可以解决。我在查看网络状态的时候发现,居然保留了上次实验的建立的s1,s2网桥,好在用了删除的命令操作后并没有什么太大影响。一开始使用wireshark还有些不熟悉,后面都能够自如应用,还是有所进步的我感觉。