zoukankan      html  css  js  c++  java
  • 实验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=OpenFlow10
    • 连接Ryu控制器
      ryu-manager ryu/ryu/app/gui_topology/gui_topology.py --observe-links

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

    • 访问http://127.0.0.1:8080

    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)
    
    • 使用ryu-manager L2Switch.py运行
    • h1 ping h2

    • h1 ping h3

    • POX的Hub模块有何不同:
      Hub和L2Switch实现的都是洪泛发送ICMP报文,L2Switch下发的流表无法查看,而Hub可以查看

    个人总结

    • 遇到的问题:


    建立拓扑后出现问题,而且ping不通,要先启动控制器,再建立拓扑

    Ryu的图形界面没有显示出完整的网络拓扑

    本次实验难度不高,主要问题就是ping不同,但通过阅读别人的博客找到了解决方法。本次实验通过使用 tcpdump 验证L2Switch,学习部署Ryu控制器,和上次的pox控制器差不多

  • 相关阅读:
    ubuntu18.04管理redis
    Mac Vmware虚拟机重启后没有网络
    记Spark写数据到Elasticsearch的报错
    Spark基础和RDD
    PHP日期处理
    集群命令
    hadoop集群时间同步
    HBase读写流程
    Flume简介
    Linux 常用快捷键
  • 原文地址:https://www.cnblogs.com/rakanXayan/p/15402562.html
Copyright © 2011-2022 走看看