实验2:Open vSwitch虚拟交换机实践
一、创建OVS交换机,并以ovs-switchxxx命名。
在创建的交换机上增加端口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的连通性。
二、使用Mininet搭建的SDN拓扑,如下图所示,要求支持OpenFlow 1.3协议,主机名、交换机名以及端口对应正确。
三、通过命令行终端输入“ovs-ofctl”命令,直接在s1和s2上添加流表,划分出所要求的VLAN。
四、主机连通性要求:
- h1 - h3互通
- h2 - h4互通
- 其余主机不通
进阶要求
#!/usr/bin/env python
import os
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 myNetwork():
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.1.1', defaultRoute=None)
h2 = net.addHost('h2', cls=Host, ip='10.0.1.2', defaultRoute=None)
h3 = net.addHost('h3', cls=Host, ip='10.0.1.3', defaultRoute=None)
h4 = net.addHost('h4', cls=Host, ip='10.0.1.4', defaultRoute=None)
info( '*** Add links\n')
net.addLink(s1, s2, 3, 3)
net.addLink(h1, s1, 1, 1)
net.addLink(h2, s1, 1, 2)
net.addLink(h3, s2, 1, 1)
net.addLink(h4, s2, 1, 2)
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])
os.system('ovs-ofctl -O OpenFlow13 add-flow s1 priority=1,in_port=1,actions=push_vlan:0x8100,set_field:4096-\>vlan_vid,output:3')
os.system('ovs-ofctl -O OpenFlow13 add-flow s1 priority=1,in_port=2,actions=push_vlan:0x8100,set_field:4097-\>vlan_vid,output:3')
os.system('ovs-ofctl -O OpenFlow13 add-flow s2 priority=1,in_port=1,actions=push_vlan:0x8100,set_field:4096-\>vlan_vid,output:3')
os.system('ovs-ofctl -O OpenFlow13 add-flow s2 priority=1,in_port=2,actions=push_vlan:0x8100,set_field:4097-\>vlan_vid,output:3')
os.system('ovs-ofctl -O OpenFlow13 add-flow s1 priority=1,dl_vlan=0,actions=pop_vlan,output:1')
os.system('ovs-ofctl -O OpenFlow13 add-flow s1 priority=1,dl_vlan=1,actions=pop_vlan,output:2')
os.system('ovs-ofctl -O OpenFlow13 add-flow s2 priority=1,dl_vlan=0,actions=pop_vlan,output:1')
os.system('ovs-ofctl -O OpenFlow13 add-flow s2 priority=1,dl_vlan=1,actions=pop_vlan,output:2')
os.system('ovs-vsctl show')
CLI(net)
net.stop()
if __name__ == '__main__':
setLogLevel( 'info' )
myNetwork()
实验总结
个人总结与想法
本次实验相较于上一次难度有所提升,但结合课堂更好的理解运用了所学的SDN理论知识。我个人认为自己有了细微的进步,值得为自己在心里喝彩一回。望之后能更上一层楼。
困难与解决方法
1、创建ovs交换机端口时,多次尝试始终无法在终端执行创建命令(均报错显示交换机或端口已存在)。后多方查找得知创建完ovs交换机后既然交换机和端口均已存在直接执行sudo ovs-vsctl set Interface p0 ofport_request=100 type=internal就能够完成端口设置。
2、添加流表时,由于对于终端上添加流表命令不熟悉,导致只有h1和h3能够互通,其余全部不通。仔细查看自己所输入的命令后发现s2端口添加流表中有一条set field值为4096+vlan_id,修改为4097+vlan_id后就实现了实验要求。
- PS:
1、拓扑python文件mininet运行时,想打开终端完成添加流表操作,可直接点击左上角类似+的按钮即可。
2.dpctl dump-flows可直接在mininet下查看流表信息