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

发布时间:2022-07-05 发布网站:脚本宝典
脚本宝典收集整理的这篇文章主要介绍了实验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-switch091命名,其中091为本人在班中的序号。在创建的交换机上增加端口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交换机,以90学号命名
sudo ovs-vsctl add-br ovs-switch090
//创建端口p0,设置编号为100
sudo ovs-vsctl add-port ovs-switch090 p0
sudo ovs-vsctl set Interface p0 ofport_request=100 type=internal
//创建端口p1,设置编号为101
sudo ovs-vsctl add-port ovs-switch090 p1
sudo ovs-vsctl set Interface p1 ofport_request=101 type=internal
//创建一个虚拟网络空间ns0,将p0移入
sudo ip netns add ns0
sudo ip link set p0 netns ns0
sudo ip netns exec ns0 ip addr add 192.168.0.100/24 dev p0
sudo ip netns exec ns0 ifconfig p0 promisc up
//创建一个虚拟网络空间ns1,将p1移入
sudo ip netns add ns1
sudo ip link set p1 netns ns1
sudo ip netns exec ns1 ip addr add 192.168.0.101/24 dev p1
sudo ip netns exec ns1 ifconfig p1 PRomisc up
//查看网络状态
sudo ovs-vsctl show
//p0和p1连通性测
sudo ip netns exec ns0 ping 192.168.0.101
sudo ip netns exec ns1 ping 192.168.0.100
@H_195_126@

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

 

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

2.使用Mininet搭建的SDN拓扑,要求支持OpenFlow 1.3协议,主机名、交换机名以及端口对应正确。运行sudo ../mininet/examples/miniedit.py运行可视化界面搭建目标拓扑

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

支持OpenFlow 1.3协议 (记得勾选start CLI选项)

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

    保存为python脚本

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

    •  编辑python文件:主机名、交换机名以及端口对应正确

         

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

运行python脚本生成拓扑

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

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

//使用ovs-ofctl下发流表,配置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:Open vSwitch虚拟交换机实践

4.主机连通性要求

-h1 – h3互通 -h2 – h4互通 -其余主机不通

在mininet命令下输入pingall

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

终端输入sudo Wireshark,mininet命令行输入pingall,抓取h1发往h3的包

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

可知VLAN标记为0

抓取h2发往h4的包

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

可知VLAN标记为1

四.个人总结

出现了如下错误 :

1.s1 is not a bridge or a socket       在新建终端内输入

2.保存为py文件后,为只读文件无法修改    输入sudo chmod 666 XXX.py改为可读写文件

 

脚本宝典总结

以上是脚本宝典为你收集整理的实验2:Open vSwitch虚拟交换机实践全部内容,希望文章能够帮你解决实验2:Open vSwitch虚拟交换机实践所遇到的问题。

如果觉得脚本宝典网站内容还不错,欢迎将脚本宝典推荐好友。

本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。