实验目的
- 能够对Open vSwitch进行基本操作
- 能够通过命令行终端使用OVS命令操作Open vSwitch交换机,管理流表
- 能够通过Mininet的Python代码运行OVS命令,控制网络拓扑中的Open vSwitch交换机
(一)基本实验
实验1 创建OVS交换机
在/home/用户名/学号/lab2/目录下执行ovs-vsctl show命令、以及p0和p1连通性测试的执行结果截图。
- 创建OVS交换机。
- 为OVS交换机配置p0端口,并创建虚拟空间ns0,将p0移入虚拟网络空间ns0,同时配置IP。
- 为OVS交换机配置p1端口,并创建虚拟空间ns1,将p1移入虚拟网络空间ns1,同时配置IP。
- 测试联通性,成功ping通。
实验2 Mininet下发流表
在/home/用户名/学号/lab2/目录下开启Mininet CLI并执行pingall命令的截图、上述目录下查看OVS流表的命令结果截图,wireshark抓包截图。
- 自定义拓扑,修改端口号,同时执行pingall命令。
- 划分VLAN,为s1,s2配置流表项,同时查看下发的流表项。
- 验证结果,同时pingall,用wireshark抓包。
(二)进阶实验
代码如下
``
!/usr/bin/env python
from mininet.net import Mininet
from mininet.node import Controller, RemoteController, OVSController
from mininet.node import CPULimitedHost, Host, Node
from mininet.node import OVSKernelSwitch, UserSwitch
from mininet.node import IVSSwitch
from mininet.cli import CLI
from mininet.log import setLogLevel, info
from mininet.link import TCLink, Intf
from subprocess import call
def mynet():
net = Mininet( topo=None,build=False,ipBase='10.0.0.0/8')
info( '*** Adding controller\n' )
c0=net.addController(name='c0',controller=Controller,protocol='tcp',port=6633)
info( '*** Add switches\n')
s1 = net.addSwitch('s1', cls=OVSKernelSwitch)
s2 = net.addSwitch('s2', cls=OVSKernelSwitch)
info( '*** Add hosts\n')
h1 = net.addHost('h1', cls=Host, ip='10.0.0.1', defaultRoute=None)
h2 = net.addHost('h2', cls=Host, ip='10.0.0.2', defaultRoute=None)
h3 = net.addHost('h3', cls=Host, ip='10.0.0.3', defaultRoute=None)
h4 = net.addHost('h4', cls=Host, ip='10.0.0.4', defaultRoute=None)
info( '*** Add links\n')
net.addLink(s1, h1)
net.addLink(s1, h2)
net.addLink(s2, h3)
net.addLink(s2, h4)
net.addLink(s1, s2)
info( '*** Starting network\n')
net.build()
info( '*** Starting controllers\n')
for controller in net.controllers:
controller.start()
info( '*** Starting switches\n')
net.get('s1').start([c0])
net.get('s2').start([c0])
info( '*** Post configure switches and hosts\n')
s1.cmd('sudo ovs-ofctl -O OpenFlow13 add-flow s1 priority=1,in_port=1,actions=push_vlan:0x8100,set_field:4096-\>vlan_vid,output:3')
s1.cmd('sudo ovs-ofctl -O OpenFlow13 add-flow s1 priority=1,in_port=2,actions=push_vlan:0x8100,set_field:4097-\>vlan_vid,output:3')
s1.cmd('sudo ovs-ofctl -O OpenFlow13 add-flow s1 priority=1,dl_vlan=0,actions=pop_vlan,output:1')
s1.cmd('sudo ovs-ofctl -O OpenFlow13 add-flow s1 priority=1,dl_vlan=1,actions=pop_vlan,output:2')
s2.cmd('sudo ovs-ofctl -O OpenFlow13 add-flow s2 priority=1,in_port=1,actions=push_vlan:0x8100,set_field:4096-\>vlan_vid,output:3')
s2.cmd('sudo ovs-ofctl -O OpenFlow13 add-flow s2 priority=1,in_port=2,actions=push_vlan:0x8100,set_field:4097-\>vlan_vid,output:3')
s2.cmd('sudo ovs-ofctl -O OpenFlow13 add-flow s2 priority=1,dl_vlan=0,actions=pop_vlan,output:1')
s2.cmd('sudo ovs-ofctl -O OpenFlow13 add-flow s2 priority=1,dl_vlan=1,actions=pop_vlan,output:2')
CLI(net)
net.stop()
if name == 'main':
setLogLevel( 'info' )
mynet() ``
保存为032002211-test2-mytopo.py,执行结果如下,符合条件
个人总结
- 个人认为实验难度适中,按照老师给的资料顺序执行即可。
- 学习了ovsctrl 和 mininet 的配合使用,并学习了如何使用控制行实现流表下发。
- 通过进阶实验学习到了通过 py 脚本控制基础部分所学知识的方法、并巩固了python脚本的知识。
实验中遇到的困难 - 个人认为pdf给的第一个实验有问题,p0应该对应192.168.0.100。
- 做第二个流表实验,显示s0:is not a socket and bridege。后来发现要在另一个终端先运行脚本,才能进行实验。