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. 解决IE下Ajax请求无效

    在做web开发是,大多时候都会使用FireFox作为调试的浏览器.上面携带的FireBug用来调试JavaScript实在是太方便了,绝大多数的问题都能够通过它跟踪调试出来.但是,当项目发布时,不能仅 ...

  2. 用Ghostscript API将PDF格式转换为图像格式(C#)

    原文:用Ghostscript API将PDF格式转换为图像格式(C#) 由于项目需要在.net下将pdf转换为普通图像格式,在网上搜了好久终于找到一个解决方案,于是采用拿来主义直接用.来源见代码中注 ...

  3. [python]自问自答:python -m参数? (转)

    python -m xxx.py 作用是:把xxx.py文件当做模块启动但是我一直不明白当做模块启动到底有什么用.python xxx.py和python -m xxx.py有什么区别! 自问自答: ...

  4. window.open的小技巧分享(转)

    今天再次谈起window.open是因为发现了一个比较好玩的小技巧,详细内容我们稍后详细说明.       聊到window.open,不得不说明一下他的使用方法,主要有两种形式:   window. ...

  5. linux编curlDLL库so

    转载请注明出处:帘卷西风的专栏(http://blog.csdn.net/ljxfblog) curl库是一个非常强大的http开源库.c++里面可以非常方便的和httpserver交互. 近期项目開 ...

  6. nmap 使用注意事项

    1.可行的网络主机的高速发现 nmap -sP 192.168.1.*  要么 nmap -sP 192.168.1.-254 2.扫描UDPport DP扫描方式用于推断UDPport的情况. 向目 ...

  7. WPF:警惕TextBox会占用过多内存

    原文:WPF:警惕TextBox会占用过多内存 问题源自这篇文章:WPF的TextBox产生内存泄露的情况. 整个问题是这样的,文章作者演示使用类似下方的代码来不停地像WPF的TextBox控件赋值: ...

  8. 选择一个利于SEO的空间

    大家好.今天蜗牛将给大家分享怎么选择一个利于SEO的站点空间. 一.什么是站点空间? 站点空间,是用来存你的站点的HTML,.图片.文件等的一个远程硬盘空间(就像你的电脑里面的空间一回事儿).依据不同 ...

  9. 国产与第三方库FFmpeg SDK

    一个.编译并安装第三方库 1. libfaac # tar -zxvf faac-1.28.tar.gz # cd faac-1.28 # ./configure --prefix=/opt/YOUR ...

  10. Java流

    流是一组有顺序的,有起点和终点的字节集合,是对传输数据的总称或抽象.即数据在两设备间的传输称为流,流的本质是传输数据,依据传输数据特性将流抽象为各种类,方便更直观的进行数据操作. 流的分类: 数据类型 ...