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


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


一、实验目的

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

二、实验环境

  1. 下载虚拟机软件Oracle VisualBox 或 VMware;
  2. 在虚拟机中安装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:Open vSwitch虚拟交换机实践
    ovs-vsctl show命令执行结果:
    实验2:Open vSwitch虚拟交换机实践
    连通性测试:
    实验2:Open vSwitch虚拟交换机实践
  2. 使用Mininet搭建的SDN拓扑,如下图所示,要求支持OpenFlow 1.3协议,主机名、交换机名以及端口对应正确。
    实验2:Open vSwitch虚拟交换机实践

     

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

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

     

     生成网络拓扑:

    实验2:Open vSwitch虚拟交换机实践
  3. 通过命令行终端输入“ovs-ofctl”命令,直接在s1和s2上添加流表,划分出所要求的VLAN。
    VLAN_ID Hosts
    0 h1 h3
    1 h2 h4
    实验2:Open vSwitch虚拟交换机实践

     

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

  4. 主机连通性要求:

    h1 – h3互通

    h2 – h4互通

    其余主机不通

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

     

    h1和h3互通,h2和h4互通,其他主机不互通。
    命令行中输入下述指令查看下发流表
    实验2:Open vSwitch虚拟交换机实践

     

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

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

     

     

    对h1和h3发送的包标记为0
    实验2:Open vSwitch虚拟交换机实践

     

     对h2和h4发来的包标记为1,符合要求。
    实验2:Open vSwitch虚拟交换机实践

     

     

     

四、个人总结

本次实验整体不算太顺利,一开始创建交换机的时候直接粘贴了pdf的switch000报错,修改之后创建端口也报错,还有配置虚拟空间的时候一直显示Cannot find什么什么的,不过并没有影响到后面的实验。我把交换机删了重新创建一个就可以了。后面在修改拓扑文件的时候也遇到了问题,经过百度的帮助学会了在ubuntu系统中修改文件可读写状态。本次实验中我也学会了wireshark的使用以及了解了相关的知识,不过由于能力有限,未能完成进阶作业,以后会继续学习提升自己。

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


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