国产xxxx99真实实拍_久久不雅视频_高清韩国a级特黄毛片_嗯老师别我我受不了了小说

資訊專欄INFORMATION COLUMN

Floodlight 源碼解讀 :Main

verano / 1754人閱讀

摘要:每個具體的模塊都會重寫這幾個函數,下面舉個的例子。獲得的服務返回服務實現類和實現用的對象的。服務是指繼承了接口的類。模塊使用方法可以獲得對應的服務列表,可以到源碼去看對應的服務功能。

Floodlight 的 Main 解析圖

需要理解的概念 模塊(Module)

Module 是指繼承了 IFloodlightModule 接口的類

IFloodlightModule的相關注釋

 
 Defines an interface for loadable Floodlight modules.
 At a high level, these functions are called in the following order:
 
  getModuleServices() : 獲得模塊實現的服務列表
  getServiceImpls(); 實例化并返回:服務實現類-實現此服務的對象 映射
  getModuleDependencies() : 獲得模塊依賴的列表
  init() : internal initializations (don"t touch other modules)
  startUp() : external initializations (do touch other modules)

所有可加載的模塊都有這幾種方法,在接下來的加載模塊時需要使用到。
每個具體的模塊都會重寫這幾個函數,下面舉個 FloodlightProvider 的例子。

getModuleServices()
@Override
public Collection> getModuleServices() {
    Collection> services =
            new ArrayList>(1);
    services.add(IFloodlightProviderService.class);
    return services;
}

獲得 FloodlightProvider 的服務 IFloodlightProviderService

getServiceImple()
@Override
public Map,
           IFloodlightService> getServiceImpls() {
    controller = new Controller();

    Map,
        IFloodlightService> m =
            new HashMap,
                        IFloodlightService>();
    m.put(IFloodlightProviderService.class, controller);
    return m;
}

返回服務實現類和實現用的對象的Map。

getModuleDependencies()
@Override
public Collection> getModuleDependencies() {
    Collection> dependencies =
        new ArrayList>(4);
    dependencies.add(IStorageSourceService.class);
    dependencies.add(IPktInProcessingTimeService.class);
    dependencies.add(IRestApiService.class);
    dependencies.add(IDebugCounterService.class);
    dependencies.add(IOFSwitchService.class);
    dependencies.add(IThreadPoolService.class);
    dependencies.add(ISyncService.class);
    return dependencies;
}

返回依賴的列表

其他

init(),startup(),到對應的模塊去看就可以了。
有的模塊是沒有服務依賴的,比如 ThreadPool模塊。

服務(Service)

Service 是指繼承了 IFloodlightService 接口的類。

public abstract interface IFloodlightService {
   // This space is intentionally left blank....don"t touch it
}

模塊使用getModuleServices()方法可以獲得對應的服務列表,可以到源碼去看對應的服務功能。

Main函數

解析命令行參數

加載模塊

啟動 REST 服務器

啟動 Controller

命令行參數解析

CmdLineSetting 定義了命令行參數的格式

public static final String DEFAULT_CONFIG_FILE = "src/main/resources/floodlightdefault.properties";

@Option(name="-cf", aliases="--configFile", metaVar="FILE", usage="Floodlight configuration file")
private String configFile = DEFAULT_CONFIG_FILE;

如果沒有使用-cf指定配置文件路徑,則使用默認路徑“src/main/resources/floodlightdefault.properties”

CmdLineParser 解析命令參數

CmdLineParser parser = new CmdLineParser(settings)
parser.parserArgument(args)
加載模塊

moduleContext=fml.loadModulesFromConfig(settings.getModuleFile())
settings.getModuleFile()提供配置文件的路徑

mergeProperties()

目的是獲得配置文件里的模塊的集合configMods和prop是除去配置文件里的模塊鍵值對后剩余的配置信息(模塊的配置參數)

loadModulesFromList(configsMods,prop)
findAllModule(configMods)

填充moduleNameMap,moduleServiceMap,ServiceMap

這個方法比較重要的是這個 ServiceLoader,返回服務加載器

ServiceLoader moduleLoader =
            ServiceLoader.load(IFloodlightModule.class, cl);

ServiceLoader 為了注冊服務,需要在類路徑 src/main/resources/META_INF/services文件夾內列好注冊服務的模塊,可以得到繼承了 IFloodlightModule 接口的實現類
使用moduleLoader.iterator()迭代器去填充moduleNameMap,moduleServiceMap,ServiceMap
moduleNameMap 模塊名稱-模塊對象 Map
moduleServiceMAP 模塊名稱-模塊服務 Map
ServiceMap 模塊服務-模塊名稱 Map

traverseDeps(moduleName,modsToLoad,moduleList,moduleMap,modsVisited)
addModule()

添加模塊到模塊的哈希集moduleMap,同時注冊它們的服務(即得到已加載模塊序列 moduleList)

parseConfigParameters(prop)

解析每個模塊的配置參數

取配置文件的一條參數配置net.floodlightcontroller.forwarding.Forwarding.match=in-port, vlan, mac, ip, transport舉例

key:net.floodlightcontroller.forwarding.Forwarding.match

String configKey=key.substring(LastPeriod+1)

獲到的就是 match,即 configKey=match

String systemKey = System.getProperty(key);
if (systemKey != null) {
            configValue = systemKey;
        } else {
            configValue = prop.getProperty(key);
        }

如果系統屬性已經存在,則使用系統屬性的值,如果不存在,則configValue = prop.getProperty(key);【即 configValue 在此處為in-port, vlan, mac, ip, transport】

floodlightModuleContext.addConfigParam(mod,configKey,configValue)

添加模塊的配置參數

FloodlightModuleLoader 類下的方法

public void addConfigParam(IFloodlightModule mod, String key, String value) {
    Map moduleParams = configParams.get(mod.getClass());
    if (moduleParams == null) {
        moduleParams = new HashMap();
        configParams.put(mod.getClass(), moduleParams);
    }
    moduleParams.put(key, value);
}
initModules(moduleList)

初始化已加載模塊列表下的模塊

獲得模塊的服務實例

Map,
            IFloodlightService> simpls = module.getServiceImpls();

添加服務到 floodlightModuleContext

if (floodlightModuleContext.getServiceImpl(s.getKey()) == null) {
                    floodlightModuleContext.addService(s.getKey(),
                                                       s.getValue());

遍歷已加載模塊集,開始初始化模塊,調用模塊的方法:init

for (IFloodlightModule module : moduleSet) {
        // init the module
        if (logger.isDebugEnabled()) {
            logger.debug("Initializing " +
                         module.getClass().getCanonicalName());
        }
        module.init(floodlightModuleContext);
    }
startupModules(moduleList)

調用已加載模塊的啟動方法

遍歷已加載模塊集,調用每個模塊的啟動方法

for (IFloodlightModule m : moduleSet) {
        if (logger.isDebugEnabled()) {
            logger.debug("Starting " + m.getClass().getCanonicalName());
        }
        m.startUp(floodlightModuleContext);
    }
return floodlightModuleContext

返回公共環境變量

fml.runModules()

運動控制器模塊和所有模塊

getModuleList()

獲得一個按初始化順序的模塊列表

返回一個不可修改的已加載模塊序列,如果沒被初始化則返回 null

public List getModuleList() {
    if (loadedModuleList == null)
        return Collections.emptyList();
    else
        return Collections.unmodifiableList(loadedModuleList);
}

runModules()

for (IFloodlightModule m : getModuleList()) {
        for (Method method : m.getClass().getDeclaredMethods()) {
            Run runAnnotation = method.getAnnotation(Run.class);
            if (runAnnotation != null) {
                RunMethod runMethod = new RunMethod(m, method);
                if(runAnnotation.mainLoop()) {
                    mainLoopMethods.add(runMethod);
                } else {
                    runMethod.run();
                }
            }
        }
    }

for 循環遍歷模塊中的方法,找到@run注解的方法為主方法,以下的就是 FloodlightProvider 提供的 run 方法

@Run(mainLoop=true)
public void run() throws FloodlightModuleException {
    controller.run();
}

運行控制器的模塊

 mainLoopMethods.get(0).run();

文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。

轉載請注明本文地址:http://specialneedsforspecialkids.com/yun/76541.html

相關文章

  • Floodlight 源碼解讀FloodlightProvider

    摘要:每個消息將通過一個的線程進行處理,并執行與所有模塊的消息相關聯的所有邏輯其他模塊也可以注冊類似交換機連接或斷開和端口狀態通知特定時間。默認情況下,使用地址和來識別設備。設備管理器將了解其他屬性,如地址。在消息轉發實現前,模塊將啟動。 FloodlightProvider 處理交換機之間的連接并將 OpenFlow 的消息轉化成其他模塊可以監聽的時間 決定某些特定的 OpenFLow ...

    dadong 評論0 收藏0
  • React 源碼深度解讀(四):首次自定義組件渲染 - Part 1

    摘要:本篇開始介紹自定義組件是如何渲染的。組件將自定義組件命名為,結構如下經過編譯后,生成如下代碼構建頂層包裝組件跟普通元素渲染一樣,第一步先會執行創建為的。調用順序已在代碼中注釋。先看圖,這部分內容將在下回分解 前言 React 是一個十分龐大的庫,由于要同時考慮 ReactDom 和 ReactNative ,還有服務器渲染等,導致其代碼抽象化程度很高,嵌套層級非常深,閱讀其源碼是一個非...

    Warren 評論0 收藏0
  • 跟著大彬讀源碼 - Redis 1 - 啟動服務,程序都干了什么?

    摘要:此時服務器處于休眠狀態,并使用進行事件輪詢,等待監聽事件的發生。繼續執行被調試程序,直至下一個斷點或程序結束縮寫。服務啟動包括初始化基礎配置數據結構對外提供服務的準備工作還原數據庫執行事件循環等。 一直很羨慕那些能讀 Redis 源碼的童鞋,也一直想自己解讀一遍,但迫于 C 大魔王的壓力,解讀日期遙遙無期。 相信很多小伙伴應該也都對或曾對源碼感興趣,但一來覺得自己不會 C 語言,二來也...

    sewerganger 評論0 收藏0
  • k8s與日志--journalbeat源碼解讀

    摘要:但是也存在諸多的問題,隨著新設備的出現以及對安全的重視,這些缺點越發顯得突出,例如日志消息內容無法驗證數據格式松散日志檢索低效有限的元數據保存無法記錄二進制數據等。該服務可以為項目增加一定數量的元數據。 前言 對于日志系統的重要性不言而喻,參照滬江的一篇關于日志系統的介紹,基本上日志數據在以下幾方面具有非常重要的作用: 數據查找:通過檢索日志信息,定位相應的 bug ,找出解決方案 ...

    Amio 評論0 收藏0

發表評論

0條評論

最新活動
閱讀需要支付1元查看
<