以“一个包在交换机上匹配失败,向控制器上发packet_in包,控制器计算出路径,给该路径上所有交换机下发相应流表项”这个过程为例,分析floodlight中forwarding模块源码。
说明:floodlight采用事件驱动的异步框架。有三个基本组件module、service和listener,floodlight由许多module组成,每个module实现一个基本功能,同时实现对应的service接口。Service由module实现,向其他module提供服务。Listener作为监听器,采用观察者模式实现,被观察者(module)内部维护一个观察者列表,当事件发生时,被观察者通知列表中注册的观察者,观察者实现listener接口内部的方法,在方法中编写感兴趣的代码。
(需要补充学习java设计模式中的观察者模式,是一个很实用,经常出现的设计模式。)
一、Forwarding.java继承关系介绍
(1)Forwarding.java类继承自ForwardingBase类,ForwardingBase是一个抽象类,内部有很多具体方法和部分抽象方法,Forwarding实现了抽象方法,同时调用ForwardingBase中的具体方法实现其他功能。(java设计模式中的模板方法模式)
(2)实现了IfloodlightModule,表示Forwarding类是作为一个独立的模块添加到floodlight中。<