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

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

一、实验目的

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

二、实验环境

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

三、实验要求

  • 1、完成ryu控制器的安装

  • 查看ryu控制器的版本

  • 2、搭建下图所示SDN拓扑,协议使用Open Flow 1.0,并连接Ryu控制器。

  • 使用sudo mn --topo=single,3 --mac --controller=remote,ip=127.0.0.1,port=6633 --switch ovsk,protocols=OpneFlow10构建拓扑,并连接到ryu控制器

  • 3、通过Ryu的图形界面查看网络拓扑。

  • 启动ryu控制器, 查看拓扑

  • 4、阅读Ryu文档的The First Application一节,运行并使用 tcpdump 验证L2Switch,分析和POX的Hub模块有何不同。

  • L2Switch.py


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)

  • 验证 LSwitch 功能

  • h1 ping h2 , h2和h3都能收到数据包

  • h1 ping h3 , 同样h2和h3都能收到数据包

得出:Hub和L2Switch实现的都是洪泛发送ICMP报文,比如当h1 ping h2时,h1发送给h2的ICMP报文,h3也会收到,但L2Switch下发的流表无法查看,而Hub可以查看。

四、实验总结:

  • 学会了ryu控制器的相关知识,验证了pox中hub模块功能,同时通过阅读源码,了解了 simple_switch_13流规则下发机制
  • 注意到了运行顺序,要先运行ryu控制器后在建立拓扑,不然后面验证tcpdump模块是会ping不通
posted @ 2021-10-20 11:35  -ACE  阅读(221)  评论(0编辑  收藏  举报