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

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

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

  • 下载虚拟机软件Oracle VisualBox 或 VMware;
  • 在虚拟机中安装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的连通性。
  • 成功创建ovs交换机,并按照题目要求配置
  • 创建ovs交换机,以ovs-switch068为例命名

sudo ovs-vsctl add-br ovs-switch068

sudo ovs-vsctl add-br ovs-switch068

创建端口p0,设置编号为100,类型为“internal”

sudo ovs-vsctl add-port ovs-switch068 p0

sudo ovs-vsctl set Interface p0 ofport_request=100 type=internal

sudo ethtool -i p0 #查询p0网口的相关信息

创建一个虚拟网络空间ns0,把p0接口移入网络空间ns0,并配置IP地址为 192.168.1.100

sudo ip netns add ns0

sudo ip link set p0 netns ns0

sudo ip netns exec ns0 ip addr add 192.168.1.100/24 dev p0

sudo ip netns exec ns0 ifconfig p0 promisc up

sudo ovs-vsctl add-port ovs-switch068 p1

sudo ovs-vsctl set Interface p0 ofport_request=101 type=internal

sudo ethtool -i p1 #查询p0网口的相关信息

创建一个虚拟网络空间ns1,把p1接口移入网络空间ns1,并配置IP地址为 192.168.1.100

sudo ip netns add ns1

sudo ip link set p1 netns ns1

sudo ip netns exec ns1 ip addr add 192.168.1.100/24 dev  p1

sudo ip netns exec ns1 ifconfig p1 promisc up
```

sudo ovs-vsctl show查看ovs交换机状态

 

 


sudo ip netns exec ns0 ping 192.168.0.101测试p0和p1的连通性,连通性良好

 

 

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

 

 

生成拓朴

保存为python脚本

 

 

 

 

 

对link对应端口进行修改

 

 

 

 

生成网络拓扑

 

 

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

 

 

将主机1,2发送来的包打上vlan标记

sudo ovs-ofctl -O OpenFlow13 add-flow s1 priority=1,in_port=1,actions=push_vlan:0x8100,set_field:4096->vlan_vid,output:3
sudo ovs-ofctl -O OpenFlow13 add-flow s1 priority=1,in_port=2,actions=push_vlan:0x8100,set_field:4097->vlan_vid,output:3

将主机3,4发送来的包取出vlan标记

sudo ovs-ofctl -O OpenFlow13 add-flow s1 priority=1,dl_vlan=0,actions=pop_vlan,output:1
sudo ovs-ofctl -O OpenFlow13 add-flow s1 priority=1,dl_vlan=1,actions=pop_vlan,output:2

将主机3,4发送来的包打上vlan标记

sudo ovs-ofctl -O OpenFlow13 add-flow s2 priority=1,in_port=1,actions=push_vlan:0x8100,set_field:4096->vlan_vid,output:3
sudo ovs-ofctl -O OpenFlow13 add-flow s2 priority=1,in_port=2,actions=push_vlan:0x8100,set_field:4097->vlan_vid,output:3

将主机1,2发送来的包取出vlan标记

sudo ovs-ofctl -O OpenFlow13 add-flow s2 priority=1,dl_vlan=0,actions=pop_vlan,output:1
sudo ovs-ofctl -O OpenFlow13 add-flow s2 priority=1,dl_vlan=1,actions=pop_vlan,output:2


主机连通性要求

h1 – h3互通

h2 – h4互通

其余主机不通

 

 

命令行中输入下述指令查看下发流表

 

 

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

 

 

 

 

实验遇到的困难,第一个就是创建了p0没创建p1,之后改正了。再一个就是一直遇到s0无效的情况,原来是拓扑的代码中的连接方式没有修改,又遇到了代码文件是只读的,然后询问同学,采用’sudo chmod 777 031902615.py'.将文件改为可修改类型的。之后的话倒是问题不大。此外还学会了wireshark命令。
学习到的内容,一个就是学习到了交换机的一些基础,刚刚开始不是很懂,然后上网查了其他博主的解析博客,感觉自己会了一些。但是对于vlan的划分还是不理解,出结果都是照猫画虎照样子输入代码的出来的。总之,通过这次实我感觉增强了自己的一个探索和坚持的品质,也增强了自己对于数据通信这个科目的理解。

posted @ 2021-09-21 22:05  夕顔  阅读(111)  评论(0编辑  收藏  举报