实验6:开源控制器实践——RYU

实验6:开源控制器实践——RYU

一、实验目的

  1. 能够独立部署RYU控制器;
  2. 能够理解RYU控制器实现软件定义的集线器原理;
  3. 能够理解RYU控制器实现软件定义的交换机原理。

二、实验环境

  1. 下载虚拟机软件Oracle VisualBox或VMware;
  2. 在虚拟机中安装Ubuntu 20.04 Desktop amd64,并完整安装Mininet;

三、实验要求

(一)基本要求

  1. 完成Ryu控制器的安装。
  2. 搭建下图所示SDN拓扑,协议使用Open Flow 1.0,并连接Ryu控制器。
  3. 通过Ryu的图形界面查看网络拓扑。
  4. 阅读Ryu文档的The First Application一节,运行并使用 tcpdump 验证L2Switch,分析和POX的Hub模块有何不同。
  • 验证 L2Switch 功能
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控制器,才能让拓扑连接。总体来说,还是十分有收获的。
posted @ 2021-10-19 20:20  xxxhp  阅读(43)  评论(0编辑  收藏  举报