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. SVN目录对号图标(更新、冲突)不显示

    长谈想知道,大约SVN这些冲突.变化.加入.不显示问题etc目录下的复选图标,退房的在线信息,多数说的更改icon的settings,后来,一点点仔细阅读SVN配有英文说明文档,我相信,改变是有点问题 ...

  2. zigbee、profile、cluster、 endpoint、

    1.引用ZigBee联盟的说法 Profile: a collection of device descriptions, which together form a cooperative appl ...

  3. CloudFoundry.yml修订

    --- name: CFRELEASE02 director_uuid: fdd46e30-f2c5-41dc-9662-0976fdac5716 releases: - name: cf versi ...

  4. 设计模式入门之装饰器模式Decorator

    //装饰模式定义:动态地给一个对象加入一些额外的职责. //就添加功能来说.装饰模式比生成子类更为灵活 //这也提现了面向对象设计中的一条基本原则,即:尽量使用对象组合,而不是对象继承 //Compo ...

  5. REST|RESTful初步认识

    工作中要用到jersey来实现restful风格的webservice.对于webservice另一定的认知(能够觉得是一种服务,远程调用的组件),可是对于restful笔者根本就木有了解过,rest ...

  6. NGUI Example5 演示示例评论– lights and Refraction

     NGUI Example5 – lights and Refraction        NUI这个系统是在是牛.比unity3D里面自带的gui要好用得多.还能够为GUI加入法线贴图! 哈哈. ...

  7. OpenGL模板 Mac Cmake OpenGL(Glut) Template

    自己经常使用的一些功能做一个模板,有灯光效果,你可以用鼠标放大,围绕所述旋转坐标系的原点 watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvcHlhbmcxOT ...

  8. JavaScript之包装对象

    JavaScript对象是一种复合值:它是属性和已命名值的集合.通过"."符号来引用属性值.当属性值是一个函数时,称为方法. ①一段你常用但却未必明白其真正底层原理的代码: var ...

  9. 标签(Tag)的各种设计方案

    标签(Tag)的各种设计方案 首先,标签(Tag)是什么? 我的理解:用来具体区分某一类内容的标识,和标签类似的一个概念是分类(Category),有一个示例可以很好的区分它们两个,比如人类分为:白种 ...

  10. kettle于javascript步骤错误处理

    javascript步骤错误处理 假设你熟悉kettle误差特性转换.你可能想知道javascript步骤如何使用.骤用户界面机制是同样的,在javascript步骤右击,选择"定义错误处理 ...