一、实验目的
- 能够理解 POX 控制器的工作原理;
- 通过验证POX的forwarding.hub和forwarding.l2_learning模块,初步掌握POX控制器的使用方法;
- 能够运用 POX控制器编写自定义网络应用程序,进一步熟悉POX控制器流表下发的方法。
二、实验环境
Ubuntu 20.04 Desktop amd64
三、实验要求
(一)基本要求
- 搭建下图所示SDN拓扑,协议使用Open Flow 1.0,控制器使用部署于本地的POX(默认监听6633端口)
输入sudo mn --topo=single,3 --mac --controller=remote,ip=127.0.0.1,port=6633 --switch ovsk,protocols=OpenFlow10
输入以上命令生成拓扑在输入
./pox.py log.level --DEBUG forwarding.hub
输入在pox文件夹以上命令打开pox
- 阅读Hub模块代码,使用 tcpdump 验证Hub模块;(1)生成拓扑下之后生成在执行xterm h1 h2 h3打开。在mininet里面执行 h1 ping h3 然后 在 h1终端中执行tcpdump -nn -i h2-eth1
能抓到h1的包 接下来在h2终端中输入tcpdump -nn -i h2-eth0
能抓到h2的包 最后在h3终端下输入tcpdump -nn -i h3-eth0
能拿到h3
- 阅读L2_learning模块代码,画出程序流程图,使用 tcpdump 验证Switch模块。以上是程序流程图
(二)进阶要求
- 重新搭建(一)的拓扑,此时交换机内无流表规则,拓扑内主机互不相通;编写Python程序自定义一个POX模块SendFlowInSingle3,并且将拓扑连接至SendFlowInSingle3(默认端口6633),实现向s1发送流表规则使得所有主机两两互通。
先重新搭建拓扑 pingall 查看情况 发现两两不相通
from pox.core import core import pox.openflow.libopenflow_01 as of class SendFlowInSingle3(object): def __init__ (self): core.openflow.addListeners(self) def _handle_ConnectionUp(self,event): #设置数据包从端口1进,从端口2和端口3出 msg = of.ofp_flow_mod()# 使用ofp_flow_mod()的方法向交换机来下发流表 msg.priority = 1#设置msg的优先级 msg.match.in_port = 1#设置在端口1接收数据包 msg.actions.append(of.ofp_action_output(port = of.OFPP_ALL))#增加转发向所有端口的动作 event.connection.send(msg)#通过send函数向交换机发送所设定的消息 #设置数据包从端口2进,从端口1和端口3出 msg = of.ofp_flow_mod() msg.priority = 1 msg.match.in_port = 2 msg.actions.append(of.ofp_action_output(port = of.OFPP_ALL)) event.connection.send(msg) #设置数据包从端口3进,从端口1和端口2出 msg = of.ofp_flow_mod() msg.priority = 1 msg.match.in_port = 3 msg.actions.append(of.ofp_action_output(port = of.OFPP_ALL)) event.connection.send(msg) def launch (): core.registerNew(SendFlowInSingle3)
以上是编写Python程序自定义一个POX模块SendFlowInSingle3。接下来启动pox,再次pingall观察情况,发现原本不相通的竟然两两相通了
个人总结:这次实验我学会了pox使用,pox这个是在一开始就安装好的mininet的环境,环境安装好了这次实验就成功了一大半。这是几个星期之前就注定的了。然后这次实验启动pox 是运行 pox.py。然后会编写简单的Python程序。这次用到的拓扑是single,这个前几次实验都用过好几次。这次实验我了解了程序流程图,然后进一步了解pox。POX是一款基于Python的SDN控制器平台,之前odl是java的sdn控制器平台,这次实验结合上次实验来可以对比两者的区别。