1. 在Main中先是载入模块,启动REST服务,而后构建一个实现了IFloodlightProviderService接口的实例(即Controller)并执行;
2. 接下来进入Controller的run()方法,此时全部的环境初始化工作已经完毕。构建一个基于netty的TCP server,最重要的是流水线factory OpenflowPipelineFactory 的设置,里面是controller上流,下流处理的handler(详细细节见===)。

当Channel建立,接收到来自OF SW的消息之后就会调用 messageReceived() 方法;依据不同的of msg类型,分发给
processOFMessage 进行详细处理;此外。假设这个消息须要进行对SW的回复,或者有其它监听者感兴趣,就呼叫 handleMessage 进行额外的处理,代码贴出来。

  protected void handleMessage(IOFSwitch sw, OFMessage m, FloodlightContext bContext){

        Ethernet eth = null;

        switch (m.getType()) {

            case PACKET_IN:

                OFPacketIn pi = (OFPacketIn)m;

                //  默认情况下总是true

                if (Controller.ALWAYS_DECODE_ETH) {

                    eth = new Ethernet();
                    //解析packet_in消息到eth中,所以以下的bcStore能够直接存储

                    eth.deserialize(pi.getPacketData(), 0, pi.getPacketData().length);

                    counterStore.updatePacketInCounters(sw, m, eth);

                }

                // fall through to default case...



            default:

               

                List<IOFMessageListener> listeners = null;

                if (messageListeners.containsKey(m.getType())) {

                    listeners = messageListeners.get(m.getType()).getOrderedListeners();

                }

                       

                FloodlightContext bc = null;

                if (listeners != null) {

                    // Check if floodlight context is passed from the calling

                    // function, if so use that floodlight context, otherwise

                    // allocate one

                    if (bContext == null) {

                        bc = flcontext_alloc();

                    } else {

                        bc = bContext;

                    }

                    if (eth != null) { 

                        IFloodlightProviderService.bcStore.put(bc,IFloodlightProviderService.CONTEXT_PI_PAYLOAD, eth);
                       
 //缓存到hashmap中。所以当我们加入自己的模块来监听packetin消息的时候。能够从中取出。做自己的业务处理。

                    }

                          

                    Command cmd;

                    for (IOFMessageListener listener : listeners) {

                        if (listener instanceof IOFSwitchFilter) {

                            if (!((IOFSwitchFilter)listener).isInterested(sw)) {

                                continue;

                            }

                        }

                         // 遍历全部对packetin感兴趣的listener。分别运行他们的receive方法;

                        cmd = listener.receive(sw, m, bc);

 

                        if (Command.STOP.equals(cmd)) {

                            break;

                        }     }    }

                      

                if ((bContext == null) && (bc != null)) flcontext_free(bc);

        }    }

3. 在循环中随时处理SW的更新消息。



版权声明:本文博客原创文章,博客,未经同意,不得转载。

Floodlight 启动过程分析的更多相关文章

  1. ASP.Net Core MVC6 RC2 启动过程分析[偏源码分析]

    入口程序 如果做过Web之外开发的人,应该记得这个是标准的Console或者Winform的入口.为什么会这样呢? .NET Web Development and Tools Blog ASP.NE ...

  2. 开机SystemServer到ActivityManagerService启动过程分析

    开机SystemServer到ActivityManagerService启动过程 一 从Systemserver到AMS zygote-> systemserver:java入层口: /** ...

  3. Neutron分析(2)——neutron-server启动过程分析

    neutron-server启动过程分析 1. /etc/init.d/neutron-server DAEMON=/usr/bin/neutron-server DAEMON_ARGS=" ...

  4. linux视频学习7(ssh, linux启动过程分析,加解压缩,java网络编程)

    回顾数据库mysql的备份和恢复: show databases; user spdb1; show tables; 在mysql/bin目录下 执行备份: ./mysqldump -u root - ...

  5. Activity启动过程分析

    Android的四大组件中除了BroadCastReceiver以外,其他三种组件都必须在AndroidManifest中注册,对于BroadCastReceiver来说,它既可以在AndroidMa ...

  6. Spark Streaming应用启动过程分析

    本文为SparkStreaming源码剖析的第三篇,主要分析SparkStreaming启动过程. 在调用StreamingContext.start方法后,进入JobScheduler.start方 ...

  7. ActivityManagerService启动过程分析

    之前讲Android的View的绘制原理和流程的时候,讲到过在Android调用setContentView之后,Android调用了一个prepreTravle的方法,这里面就提到了Activity ...

  8. Disconf源码分析之启动过程分析下(2)

    接上文,下面是第二次扫描的XML配置. <bean id="disconfMgrBean2" class="com.baidu.disconf.client.Dis ...

  9. Service启动过程分析

    Service是一种计算型组件,用于在后台执行一系列的计算任务.由于工作在后台,因此用户是无法直接感知到它的存在.Service组件和Activity组件略有不同,Activity组件只有一种运行模式 ...

随机推荐

  1. 好大滴坑, Spring MVC覆盖了Trsaction

    好大滴坑. Spring MVC覆盖了Trsaction 解决方式: <!-- package-scan 4 Spring MVC --> <context:component-sc ...

  2. JAVA CAS原理深度分析(转)

    看了一堆文章,终于把JAVA CAS的原理深入分析清楚了. 感谢GOOGLE强大的搜索,借此挖苦下百度,依靠百度什么都学习不到! 参考文档: http://www.blogjava.net/xylz/ ...

  3. c++读取文本文件

    #include<iostream> #include<fstream> using namespace std; int main() { int a,b=-100000,c ...

  4. NSIS:使用PassDialog插件实现密码安装(卸载)功能

    原文 NSIS:使用PassDialog插件实现密码安装(卸载)功能 有时,出于特殊的需求,我们要给安装或卸载程序加一个密码,只有输入了正确的密码才可以继续.比如: 下面我们使用插件来实现安装密码: ...

  5. jQuery.reveal弹出层

    jQuery.reveal弹出层使用 最近用到弹出层,还得自定义UI,原本用的artDialog太庞大,不合适了,于是就找到了这个东西,又小又好用,基础的弹出遮罩都有了,想要什么还不是Coder自己说 ...

  6. 如何让格斗游戏的横版过关(2) Cocos2d-x 2.0.4

    在第一章<如何使横版格戏>基础上.添加角色运动.碰撞.敌人.AI和音乐音效,原文<How To Make A Side-Scrolling Beat 'Em Up Game Like ...

  7. 独立博客网站FansUnion.cn操作2多年的经验和教训以及未来计划

    今天,我把运营了2年的独立博客站点FansUnion给"归零"了.    2012年6月.我成功搭建了自己的博客站点FansUnion.cn,这是因为自己的不懈努力和时代发展成就的 ...

  8. MySQL中游标使用以及读取文本数据

    原文:MySQL中游标使用以及读取文本数据 前言 之前一直没有接触数据库的学习,只是本科时候修了一本数据库基本知识的课.当时只对C++感兴趣,天真的认为其它的课都没有用,数据库也是半懂不懂,胡乱就考试 ...

  9. Hadoop-1.1.2、HBase-0.94.7完全分布式集群结构

    爱的技术可以应用到实际生活生产,做艺术向往的东西不腻和音乐. 现将前期手里面的一个项目做一个大致的总结,与大家一起分享.交流.进步. 项目如今正在线上执行,项目名--基于Hadoop的数据分析综合管理 ...

  10. cocos2d-x-2.2的SimpleAudioEngine::sharedEngine()-&gt;playEffect()计划中断bug

    在该计划已经正常,但现在突然发iphone播放声音上就挂了.播放音乐是没有问题的. android没问题. xcode给定的位置,如下面的附图: 网上搜了一下,说是有全局断点造成的.于是command ...