目录
2.app_manager.lookup_service_brick()
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.