实验6:开源控制器实践——RYU
作者:互联网
实验6:开源控制器实践——RYU
一、实验目的
- 能够独立部署RYU控制器;
- 能够理解RYU控制器实现软件定义的集线器原理;
- 能够理解RYU控制器实现软件定义的交换机原理。
二、实验环境
- 下载虚拟机软件Oracle VisualBox或VMware;
- 在虚拟机中安装Ubuntu 20.04 Desktop amd64,并完整安装Mininet;
三、实验要求
(一)基本要求
- 完成Ryu控制器的安装。
在Ryu安装目录下执行ryu --version查看版本
- 搭建下图所示SDN拓扑,协议使用Open Flow 1.0,并连接Ryu控制器。
建立拓扑连接:sudo mn --topo=single,3 --mac --controller=remote,ip=127.0.0.1,port=6633 --switch ovsk,protocols=OpenFlow10
连接Ryu控制器:ryu-manager ryu/ryu/app/gui_topology/gui_topology.py --observe-links
- 通过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
- h1 ping h3
所以可以得知:拓扑的每个主机是否收到数据包和ping哪个主机并没有直接必然的联,POX和RYU都是洪泛转发但也不完全相同,RYU不会显示下发的流表。
(二)个人总结
- 难度:易
- 实验过程遇到的困难及解决办法:
本次实验第四步骤分析和POX的Hub模块的区别阅读Ryu文档等耗费的时间较多,本次实验其余步骤都比较顺利。 - 个人感想
本次实验又进一步的加深了我对SDN软件定义网络这门课程的理解,对RYU新知识有了初步的理解,了解了L2Switch模块的洪泛转发,理解了POX的Hub模块和RYU的相似之处和不同点。
标签:控制器,ryu,Ryu,开源,ofp,msg,RYU 来源: https://www.cnblogs.com/031902324nxz/p/15428547.html