实验5:开源控制器实践——POX
实验5:开源控制器实践——POX
一、实验目的
- 能够理解 POX 控制器的工作原理;
- 通过验证POX的forwarding.hub和forwarding.l2_learning模块,初步掌握POX控制器的使用方法;
- 能够运用 POX控制器编写自定义网络应用程序,进一步熟悉POX控制器流表下发的方法。
二、实验环境
- 下载虚拟机软件Oracle VisualBox 或 VMware;
- 在虚拟机中安装Ubuntu 20.04 Desktop amd64;
三、实验要求
(一)基本要求
- 搭建下图所示SDN拓扑,协议使用Open Flow 1.0,控制器使用部署于本地的POX(默认监听6633端口)
- 阅读Hub模块代码,使用 tcpdump 验证Hub模块;
-
h1 ping h2
h3 能收到数据包
-
h1 ping h3
h2能收到数据包
- 阅读L2_learning模块代码,画出程序流程图,使用 tcpdump 验证Switch模块。
h1 ping h2
h3 不能收到数据包
h1 ping h3
h2 不能收到数据包
(二)进阶要求
- 重新搭建(一)的拓扑,此时交换机内无流表规则,拓扑内主机互不相通;编写Python程序自定义一个POX模块SendFlowInSingle3,并且将拓扑连接至SendFlowInSingle3(默认端口6633),实现向s1发送流表规则使得所有主机两两互通。
from pox.core import core
import pox.openflow.libopenflow_01 as of
from pox.openflow.of_json import *
class SendFlowInSingle3(object):
def __init__ (self):
core.openflow.addListeners(self)
def _handle_ConnectionUp(self, event):
msg = of.ofp_flow_mod()
msg.priority = 1
msg.match.in_port = 1
msg.actions.append(of.ofp_action_output(port=2))
msg.actions.append(of.ofp_action_output(port=3))
event.connection.send(msg)
msg = of.ofp_flow_mod()
msg.priority = 1
msg.match.in_port = 2
msg.actions.append(of.ofp_action_output(port=1))
msg.actions.append(of.ofp_action_output(port=3))
event.connection.send(msg)
msg = of.ofp_flow_mod()
msg.priority = 1
msg.match.in_port = 3
msg.actions.append(of.ofp_action_output(port=1))
msg.actions.append(of.ofp_action_output(port=2))
event.connection.send(msg)
def launch():
core.registerNew(SendFlowInSingle3)
(三)个人总结
-
实验中遇到的问题
- 在做进阶实验的时候,文件保存不到 pox 文件夹中,通过命令
sudo chmod 777 pox
修改了权限,可以保存文件。 - 在运行 pox 的时候报了端口被占用的错误,一开始我是通过直接重启虚拟机开解决这个问题,后来查找了一些资料,发现用命令
lsof -i:<端口号>
可以查看当前使用这个端口号的进程,再通过命令kill -s 9 <端口号>
结束这个进程就可以解决端口号被占用的问题。
- 成功运行后发现
INFO:openflow.of_01:[00-00-00-00-00-01 2] connected
,存在 2 个流表信息。原因是之前的流表信息没有清除,使用命令dpctl del-flows
清除流表,再次运行就变成INFO:openflow.of_01:[00-00-00-00-00-01 1] connected
- 在做进阶实验的时候,文件保存不到 pox 文件夹中,通过命令
-
收获
初步学习了 pox 工具,体会到了 pox 强大的功能,不用改变底层的设备结构,通过一些功能模块就能实现 Hub 和 Switch 之间的转换。