Ryu模块间通信

目录

1._CONTEXTS

2.app_manager.lookup_service_brick()

3.Event

参考文献


1._CONTEXTS

在RyuApp类中有一个属性是_CONTEXTS。_CONTEXTS中的内容将作为当前模块的服务在模块初始化时得到加载

2.app_manager.lookup_service_brick()

在某些业务场景,需要使用其他模块的数据,但又不希望将其作为自己的服务来加载,则可通过app_manager.lookup_service_brick('module name')来获取运行中的某个模块的实例,从而获取其数据。

import

引入的是静态的数据,如某个类的函数的定义,静态数据的定义。

如:名为app的模块中有一个属性self.domain = Domain(),import可以获得其类的定义。

app_manager.lookup_service_brick()

可获取动态的数据。

如:名为app的模块中有一个属性self.domain = Domain(),通过app = app_manager.lookup_service_brick(‘app’)可以获得当前的app实例,进而通过app.domain来获取当前的domain实例的数据。 

3.Event

通过事件系统来通信是模块之间通信的最普通的形式。每当交换机和Ryu建立连接,都会实例化一个Datapath对象来处理这个连接。

在Datapath对象中,将接收到的数据解析成对应的报文,进而转化成对应的事件,然后分发到各个监听该事件的监听函数,注册了对应事件的模块将收到事件,然后调用对应的handler处理事件。

 

参考文献

1.Ryu:模块间通信机制分析. http://www.muzixing.com/pages/2015/09/08/ryumo-kuai-jian-tong-xin-ji-zhi-fen-xi.html.

上一篇:NIT算法导论 字母序列


下一篇:利用JS的Canves实现打砖块小游戏