<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    OSGi R4.2 public draft中新增加的Framework launch

    這是Lifecycle Layer中的最大改進,在之前的規范中只是簡單的描述了下框架的啟動和關閉,在制定了這個規范后,以后無論是啟動equinox還是felix,都可采用同樣的方式啟動,詳細的來看看,本文摘自《OSGi原理與最佳實踐》。

    首先來看看外部應用如何通過FrameworkAPI來實現Framework的啟動,來看張啟動方法的時序圖先:


    這個時序圖完整的說明了如何通過FrameworkAPI來實現OSGi Framework的啟動和停止:

    n  調用FrameworkFactorynewFramework方法

    所有OSGi的實現都必須實現FrameworkFactory接口,此接口中只有一個方法,即newFramework(Map configuration),外部容器在實例化FrameworkFactory實現對象上有兩種做法:

    A.        Class.forName(FrameworkFactory實現類).newInstance()

    B.        通過Java 6中提供的ServiceLoader尋找并加載FrameworkFactory的實現類,使用方法為:

    假設com.acme.osgi.FactoryFrameworkFactory的實現類,那么則在META-INF下新建services目錄,在此目錄下建立一個org.osgi.framework.launch.FrameworkFactory的文件,文件內容即為:com.acme.osgi.Factory,在程序中則這么編寫來加載此FrameworkFactory實現類:

    ServiceLoader<FrameworkFactory> sl=ServiceLoader.load(FrameworkFactory.class);

    Iterator<FrameworkFactory> it=sl.iterator();

    在創建了FrameworkFactory實現的實例后,就可調用newFramework方法了,newFramework方法中的Map參數為控制OSGi框架行為的一些配置項,關鍵的有:

    n  org.osgi.framework.bootdelegation

    配置哪些package需要從boot classloader中加載,配置的值可為com.acme.*com.acme.services

    n  org.osgi.framework.executionenvironment

    配置Framework執行所需的環境,例如J2SE-1.5

    n  org.osgi.framework.library.extensions

    native code的擴展名配置,例如so,dll

    n  org.osgi.framework.startlevel

    配置Bundle啟動級別。

    n  org.osgi.framework.storage

    配置用于存儲OSGi應用運行時的Bundle狀態等信息的路徑,當此路徑不存在時,框架應負責進行創建,如創建失敗則拋出異常。

    n  org.osgi.framework.storage.clean

    配置storage目錄是否要清除,例如值配置為onFirstInit,意味著當Framework Bundle第一次初始化之前,storage目錄將被清空,這個配置項的好處是可以控制Framework重啟后是否需要根據上次運行時的狀態來啟動。

    n  org.osgi.framework.system.packages

    Frameworkparent ClassLoader應對外exportpackages

    n  org.osgi.framework.system.packages.extra

    在上面的配置項的基礎上增加了擴展屬性的配置,例如:

    org.osgi.framework.system.packages.extra=org.acme.foo;version=1.2

    n  org.osgi.framework.bundle.parent

    equinox中的osgi.parentClassLoader屬性的含義一樣,用于控制boot classloader具體是哪個classloader,有四個可選的屬性值:bootappextframework,含義和equinox完全相同。

    根據需要給這些屬性配置相應的值后,即可調用newFramework方法創建出Framework對象了。

    n  調用Frameworkinit方法

    init方法中完成Bundle Context的創建以及Framework services的注入。

    n  通過Framework獲取BundleContext

    n  安裝Bundle

    通過BundleContext.installBundle來安裝需要的Bundle

    n  調用Frameworkstart方法

    FrameworkStartLevel service設置為指定的啟動級別,從而促發已安裝的所有的Bundleresolve和啟動。

    n  調用FrameworkwaitForStop方法

    調用此方法,等待Framework的停止運行。

    按照以上說明,一個典型的基于OSGi R4.2規范的OSGi Framework的啟動過程代碼編寫示例如下:

    Map p=new HashMap();

    p.put(“org.osgi.framework.storage”,System.getProperties(“user.home”)+File.separator+”osgi”);

    FrameworkFactory factory=Class.forName(factoryClassName).newInstance();

    Framework framework=factory.newFramework(p);

    framework.init();

    BundleContext context=framework.getBundleContext();

    …//安裝Bundles

    framework.start();

    framework.waitForStop();

    對比Felix的啟動代碼,是不是覺得有點相似呢?

    OSGi規范中對Framework的生命周期也做了詳細的說明,圖示如下:


    具體來看看initstart以及stop Framework時會做哪些事情。

    n  init

    init后,需要做到以下效果:

    啟動事件分發處理功能;

    配置好Security Manager

    StartLevel設置為指定的startlevel,默認為0

    創建可用的BundleContext對象;

    所有安裝的Bundles的狀態均設置為INSTALLED

    Framework提供的services都可用;

    Framework的狀態為STARTING

    n  start

    負責根據StartLevel啟動相應的已安裝的Bundle,如Bundle啟動失敗,則廣播Framework.ERROR的事件,啟動完畢后Framework的狀態為ACTIVE

    n  stop

    負責停止所有運行的Bundle,釋放所有的資源,并將Framework的狀態置為RESOLVED

    n  update

    停止Framework,并給Framework.waitForStop方法返回STOPPED_UPDATESTOPPED_BOOTCLASSPATH_MODIFIED事件值,然后應用代碼應自行完成update處理。

    Framework規范中,OSGi還說明了Framework運行于多線程模式下,即所有Bundle都運行在各自的線程中,基于事件機制來響應其他Bundle的事件。

             從以上改動來看,增加的Framework章節是最大的改動,Framework規范的制定吸取了Felix以及Equinox的優點,對于統一OSGi Framework的啟動方式以及行為將起到很大的作用,尤其是對于嵌入OSGi框架的應用以及需要與其他容器集成的OSGi應用而言會有很大的幫助。

    posted on 2009-05-31 17:32 BlueDavy 閱讀(5295) 評論(0)  編輯  收藏 所屬分類: OSGi、SOA、SCA

    公告

     









    feedsky
    抓蝦
    google reader
    鮮果

    導航

    <2009年5月>
    262728293012
    3456789
    10111213141516
    17181920212223
    24252627282930
    31123456

    統計

    隨筆分類

    隨筆檔案

    文章檔案

    Blogger's

    搜索

    最新評論

    閱讀排行榜

    評論排行榜

    主站蜘蛛池模板: 亚洲永久中文字幕在线| 亚洲精品色婷婷在线影院| 亚洲Aⅴ在线无码播放毛片一线天| 国产精品自在自线免费观看| 国产免费内射又粗又爽密桃视频 | 亚洲三级在线观看| 亚洲午夜福利AV一区二区无码| 午夜精品免费在线观看| 另类专区另类专区亚洲| 亚洲国产美女视频| 亚洲精品456在线播放| 亚洲AV无码AV男人的天堂| 国产亚洲精午夜久久久久久| 国产成人免费ā片在线观看| 好男人www免费高清视频在线| 午夜免费啪视频在线观看| 中文字幕无码免费久久| 无码AV动漫精品一区二区免费| 亚洲另类无码专区丝袜| 亚洲人成网站色7799| 国产亚洲中文日本不卡二区| 国产成人精品日本亚洲网址| 亚洲成在人线中文字幕| 亚洲午夜国产精品无卡| 亚洲综合偷自成人网第页色| 亚洲国产精品日韩av不卡在线| 亚洲AV无码专区在线电影成人| 免费国产va在线观看| 国产在线观看免费av站| 免费日本一区二区| 免费能直接在线观看黄的视频| 最近中文字幕mv免费高清在线 | 亚洲人成电影网站| 午夜亚洲国产理论片二级港台二级| 亚洲欧美日韩中文字幕一区二区三区 | 国产亚洲欧洲Aⅴ综合一区| 亚洲AV综合色区无码一区| 亚洲一卡二卡三卡四卡无卡麻豆| 理论亚洲区美一区二区三区 | 亚洲国产精品无码专区影院| 亚洲成a人片在线看|