实验6:开源控制器实践——RYU
一、实验目的
能够独立部署RYU控制器;
能够理解RYU控制器实现软件定义的集线器原理;
能够理解RYU控制器实现软件定义的交换机原理。
二、实验环境
下载虚拟机软件Oracle VisualBox或VMware;
在虚拟机中安装Ubuntu 20.04 Desktop amd64,并完整安装Mininet;
三、实验要求
(一)基本要求
1.完成Ryu控制器的安装。
2.搭建下图所示SDN拓扑,协议使用Open Flow 1.0,运行并使用 tcpdump 验证L2Switch。
`#!/usr/bin/env python
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)
`
3.并连接Ryu控制器:sudo ryu-manager L2Switch.py
在连接拓扑:sudo mn --topo=single,3 --mac --switch ovsk --controller remote -x
4.通过Ryu的图形界面查看网络拓扑
5.运行并使用tcpdump来验证L2Switch(验证方法同POX)
1)h1 ping h2
2)h1 ping h3
由图可知,与POX的Hub模块相比的区别是:
Hub和L2Switch实现的都是洪泛发送ICMP报文,但L2Switch下发的流表无法查看,而Hub可以查看。
二)进阶要求
阅读Ryu关于simple_switch.py和simple_switch_1x.py的实现,以simple_switch_13.py为例,完成其代码的注释工作,并回答下列问题:
a) 代码当中的mac_to_port的作用是什么?
用于交换机自学习
b) simple_switch和simple_switch_13在dpid的输出上有何不同?
c) 相比simple_switch,simple_switch_13增加的switch_feature_handler实现了什么功能?
下发流表
d) simple_switch_13是如何实现流规则下发的?
e) switch_features_handler和_packet_in_handler两个事件在发送流规则的优先级上有何不同?
switch_features_handler下发流表的优先级高
实验总结:
实验难度:于我而言较难
实验过程遇到的困难及解决办法:在安装ryu上就遇到了困难,安装了好几次才成功,比较值得注意的点是要先建立L2Switch.py,在链接ryu控制器,最后再建立拓扑,ryu可视化一直没有搞出来,接下来的实验就和上一次一样了,通过ping来验证L2Switch的都是洪泛。
个人感想:此次实验主要思想和上次的大致相同,这次尝试了一下进阶任务,靠着百度强行解读了几句,大部分还是云里雾里,主要的原因是代码阅读能力不强,以及对知识的理解不够深入,收获颇多。