一、实验目的

  • 能够对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协议,主机名、交换机名以及端口对应正确。
    • 使用Mininet可视化工具搭建的SDN拓扑
    • 支持OpenFlow 1.3协议
    • 通过过修改文件使得端口对应正确
    • 确认主机名,交换机名以及端口对应情况
  • 通过命令行终端输入“ovs-ofctl”命令,直接在s1和s2上添加流表,划分出所要求的VLAN。
    • 在s1上添加流表并查看
    • 在s2上添加流表格并查看
  • 主机连通性要求:
    h1 – h3互通
    h2 – h4互通
    其余主机不通
    • 连通性结果

      可看到只有h1与h3通,h2与h4通

    • wireshark抓包结果

      可看到vlan标记0已标上

      可看到vlan标记1已标上

个人总结

  • 这次试验了解了有关openvswitch的相关知识,学到了如何通过Terminal使用ovs命令来达到操控交换机以及管理流表的方法,并再次复习巩固了使用Mininet可视化工具创建拓扑结构的流程,初步掌握了抓包工具wireshark的使用
  • 在最初创建交换机的时候发现了上次实验遗留下的s1到s14网桥,导致认为系统出现故障,后经过咨询同学得以解决。
  • 总体来讲跟着老师的教程是大致可以完成实验,同学之间的交流也是非常好的进步方法。
posted on 2021-09-22 15:07  ERROR17  阅读(104)  评论(0)    收藏  举报