实验6:开源控制器实践——RYU
一、实验目的
1.能够独立部署RYU控制器;
2.能够理解RYU控制器实现软件定义的集线器原理;
3.能够理解RYU控制器实现软件定义的交换机原理。
二、实验环境
- 下载虚拟机软件Oracle VisualBox或VMware;
- 在虚拟机中安装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都能收到数据包
- h1 ping h2 , h2和h3都能收到数据包
得出:Hub和L2Switch实现的都是洪泛发送ICMP报文,比如当h1 ping h2时,h1发送给h2的ICMP报文,h3也会收到,但L2Switch下发的流表无法查看,而Hub可以查看。
四、实验总结:
- 在用Ryu的L2Switch模块下发流表时,看到洪泛现像,但是在交换机上没有看到流表,在请教老师之后才知道,这才是Ryu与POX之间的差别
- 在ping的时候,一直ping不通,查找了很多方法,有说IP问题,都是过后还是没有用。后面参考同学作业,提示要先运行Ryu在建立topo,才成功
- 默认端口要从8080改成了6633,不然实验可能ping不通