实验6:开源控制器实践——RYU
一、实验目的
- 能够独立部署RYU控制器;
- 能够理解RYU控制器实现软件定义的集线器原理;
- 能够理解RYU控制器实现软件定义的交换机原理。
二、实验环境
- 下载虚拟机软件Oracle VisualBox或VMware;
- 在虚拟机中安装Ubuntu 20.04 Desktop amd64,并完整安装Mininet;
三、实验要求
(一)基本要求
- 完成Ryu控制器的安装。
- 搭建下图所示SDN拓扑,协议使用Open Flow 1.0,并连接Ryu控制器。
- 通过Ryu的图形界面查看网络拓扑。
- 阅读Ryu文档的The First Application一节,运行并使用 tcpdump 验证L2Switch,分析和POX的Hub模块有何不同。
from ryu.base import app_manager
from ryu.controller import ofp_event
from ryu.controller.handler import MAIN_DISPATCHER
from ryu.controller.handler import set_ev_cls
from ryu.ofproto import ofproto_v1_0
class L2Switch(app_manager.RyuApp):
OFP_VERSIONS = [ofproto_v1_0.OFP_VERSION]
def __init__(self, *args, **kwargs):
super(L2Switch, self).__init__(*args, **kwargs)
@set_ev_cls(ofp_event.EventOFPPacketIn, MAIN_DISPATCHER)
def packet_in_handler(self, ev):
msg = ev.msg
dp = msg.datapath
ofp = dp.ofproto
ofp_parser = dp.ofproto_parser
actions = [ofp_parser.OFPActionOutput(ofp.OFPP_FLOOD)]
data = None
if msg.buffer_id == ofp.OFP_NO_BUFFER:
data = msg.data
out = ofp_parser.OFPPacketOut(
datapath=dp, buffer_id=msg.buffer_id, in_port=msg.in_port,
actions=actions, data = data)
dp.send_msg(out)
- h1 ping h2, h2和h3都能收到数据包
- h1 ping h3, h2和h3同样都能收到数据包
- POX的Hub模块与RYU的L2Switch.py 的不同之处:
L2Switch下发的流表无法查看,而Hub可以查看
四、个人总结
- 在这次实验中我学到了有关RYU的使用指南,学会了如何独立部署RYU控制器,理解了RYU控制器实现软件定义的集线器原理以及RYU控制器实现软件定义的交换机原理。Ryu应用程序是在Ryu中实现各种功能的单线程实体。事件是它们之间的消息。Ryu应用程序相互发送异步事件。
- 这次的实验难度中等,遇到的问题并不太多,通过自学以及向同学请教都可以解决。有了上一次POX实验的铺垫,这次的实验做起来还算式得心应手,能够很好地运行tcpdump来验证L2Switch。期间有过拓扑不能够成功连接的问题,但最终发现是因为没有先运行RYU控制器再建立拓扑而导致。并且验证L2Switch的时候要先关闭上一次的RYU控制器,才能让拓扑连接。总体来说,还是十分有收获的。