SDN实验---Ryu的安装

一:Ryu是主流SDN开源控制器之一

(一)推文(摘录自)

https://ryu.readthedocs.io/en/latest/

https://www.sdnlab.com/1785.html

(二)Ryu是什么

Ryu is a component-based software defined networking framework.  Ryu是一个基于组件的软件定义网络框架

Ryu provides software components with well defined API's that make it easy for developers to create new network management and control applications. 
Ryu为软件组件提供了定义良好的API,使开发人员能够轻松地创建新的网络管理和控制应用程序。

Ryu supports various protocols for managing network devices, such as OpenFlow, Netconf, OF-config, etc.  支持管理网络设备的多种协议
About OpenFlow, Ryu supports fully 1.0, 1.2, 1.3, 1.4, 1.5 and Nicira Extensions.  所支持的OpenFLow协议版本
All of the code is freely available under the Apache 2.0 license. Ryu is fully written in Python.  所有代码在Apache2.0许可下都是免费的,Ryu是使用Python开发的

(三)Ryu的架构

二:Ryu的安装

(一)git远程获取文件

git clone git://github.com/osrg/ryu.git

或者

git clone https://github.com/faucetsdn/ryu.git

(二)安装Ryu依赖环境

cd ryu  需要先进入文件夹中
sudo pip install -r tools/pip-requires

(三)进行Ryu安装

sudo python setup.py install

(四)安装测试

1.常见问题及解决办法

 

 2.安装测试 

njzy@njzy-Inspiron-5493:/usr/local/bin$ ryu-manager

njzy@njzy-Inspiron-5493:/usr/local/bin$ sudo easy_install webob==1.2.3

这里有点尴尬了

参考:

https://blog.csdn.net/cyz14/article/details/79994548

https://ryu-devel.narkive.com/AvVCZ4OS/ryu-installation-error-the-ovs-distribution-was-not-found-and-is-required-by-ryu 

https://blog.csdn.net/u012424148/article/details/88951559

实际:

因为Ubuntu下,还含有一个Python3版本安装的pip3,所以我将依赖和安装中pip全部改成pip3,就安装成功了

sudo pip3 install -r tools/pip-requires
sudo python3 setup.py install
ryu-manager

安装成功:

(五)其他可能错误

1.importlib_resources中raise TypeError(f'{package!r} is not a package')

先查看已经安装的packet:使用pip3 list即可

发现提示更新,但是更新后使用pip可能出现以下问题:

因此我们需要使用正确的pip版本(注:我们python版本为3.5.2)

wget https://bootstrap.pypa.io/pip/3.5/get-pip.py
python3 get-pip.py

之后卸载原有packet:

sudo pip uninstall importlib-resources

进行重新安装:

sudo pip install importlib-resources

同样对于后面的importlib-metadata也是相同操作

2.raise NotImplementedError(f'unimplemented async backend {name}')

同上,先卸载,后安装:

3.from eventlet.wsgi import ALREADY_HANDLED --> ImportError: cannot import name 'ALREADY_HANDLED'

同样,先卸载,后安装,不过安装需要指定版本

pip install eventlet==0.30.2

三:Ryu的源码目录

(一)base

base中有一个非常重要的文件:app_manager.py,其作用是RYU应用的管理中心。用于加载RYU应用程序,接受从APP发送过来的信息,同时也完成消息的路由。

其主要的函数有app注册、注销、查找、并定义了RYUAPP基类,定义了RYUAPP的基本属性。包含name, threads, events, event_handlers和observers等成员,以及对应的许多基本函数。如:start(), stop()等。

这个文件中还定义了AppManager基类,用于管理APP。定义了加载APP等函数。不过如果仅仅是开发APP的话,这个类可以不必关心。

(二)controller

 

controller文件夹中许多非常重要的文件,如events.py, ofp_handler.py, controller.py等。其中controller.py中定义了OpenFlowController基类。用于定义OpenFlow的控制器,用于处理交换机和控制器的连接等事件,同时还可以产生事件和路由事件。其事件系统的定义,可以查看events.py和ofp_events.py。

在ofp_handler.py中定义了基本的handler句柄,完成了基本的如:握手,错误信息处理和keep alive 等功能。更多的如packet_in_handler应该在app中定义。

在dpset.py文件中,定义了交换机端的一些消息,如端口状态信息等,用于描述和操作交换机。如添加端口,删除端口等操作。

其他文件以后再叙述

(三)lib

lib中定义了我们需要使用到的基本的数据结构,如dpid, mac和ip等数据结构。在lib/packet目录下,还定义了许多网络协议,如ICMP, DHCP, MPLS和IGMP等协议内容。而每一个数据包的类中都有parser和serialize两个函数。用于解析和序列化数据包。

lib目录下,还有ovs, netconf目录,对应的目录下有一些定义好的数据类型,不再赘述。

(四)ofproto

在这个目录下,基本分为两类文件,一类是协议的数据结构定义,另一类是协议解析,也即数据包处理函数文件。
如ofproto_v1_0.py是1.0版本的OpenFlow协议数据结构的定义,而ofproto_v1_0_parser.py则定义了1.0版本的协议编码和解码。具体内容不赘述,实现功能与协议相同。

(五)topology

包含了switches.py等文件,基本定义了一套交换机的数据结构。

event.py定义了交换上的事件。

dumper.py定义了获取网络拓扑的内容。

最后api.py向上提供了一套调用topology目录中定义函数的接口。

(六)contrib

这个文件夹主要存放的是开源社区贡献者的代码。

(七)cmd

定义了RYU的命令系统,具体不赘述。

(八)services

完成了BGP和vrrp的实现。

(九)tests

tests目录下存放了单元测试以及整合测试的代码

四:Ryu和Mininet联用

(一)开启控制器,使用二层交换

~/ryu/ryu/app$ ryu-manager simple_switch.py 

(二)开启Mininet

sudo mn --controller=remote  //不指定拓扑--默认是一个交换机下面挂两个主机  --controller=remote  是将mininet的控制器指向远端控制器 未指定ip,默认0.0.0.0或者本地IP 端口默认是在6635

posted @ 2019-10-24 10:33  山上有风景  阅读(7068)  评论(0编辑  收藏  举报