基于OSGi實現可擴展的模塊的設計

          模塊的可擴展性是模塊設計時需要重點考慮的非功能特性,對于框架而言,擴展性的設計則更加的重要,框架需要通過不斷的擴展來充實其基礎設施,構成真正的應用系統。
          模塊的擴展主要有兩種,一種為擴充功能的擴展,另一種為覆蓋性質的擴展,當然,本質上而言是可以把這兩者進行合并的。
          在模塊的擴展上Eclipse的擴展點的設計方式無疑是支撐模塊可擴展的經典設計方法,到現在為止仍然是如此,基于Eclipse的擴展點的設計無論是對于擴充功能的擴展還是覆蓋性質的擴展都支持的非常好,這個經典的設計也是RCP得到那么多client side app的原因之一,盡管OSGi中并沒有定義這方面的規范,但做為OSGi R4的RI的Equinox考慮到更好的支撐Bundle的擴展就引入了Eclipse的擴展點的設計,在現在的Equinox中我們仍然可以基于Eclipse的擴展點的方式來支撐模塊的可擴展性。
          但是否有別的方法呢?一定需要Eclipse的擴展點的方式嗎?其實個人覺得基于OSGi的Service就已經天然的構成了一種可擴展的設計,為什么這么說呢?
          首先來看看基于Eclipse擴展點的方式是如何支撐模塊的可擴展性的:
          1、定義模塊的擴展點接口和xml的schema規范;
          2、在模塊需要提供擴展的地方調用所有擴展點接口的實現,并加載執行其中的一些方法。
          通過這兩步就使得模塊具備了可擴展性,典型的象Eclipse中的菜單、按鈕、幫助窗口等等....
          當需要增加新的菜單、按鈕時,只需要實現相應的擴展點接口,然后按照schema規范相應的配置xml文件就可以了。
          而基于OSGi的Service的方法怎么樣去支撐模塊的可擴展性呢,其實做法和Eclipse的擴展點的方式幾乎就是一樣的:
          1、定義模塊的擴展點接口;
          2、在模塊需要提供擴展的地方調用所有對外提供了此擴展點接口的服務組件,加載執行其中的方法。
          ????? 這一步有兩種做法,一種是通過bundleContext獲取服務的方法,另外一種是通過DS的方法,相比而言自然是DS方法操作起來更加簡單,原因在于采用DS的方法的時候當服務發生動態的變化時OSGi框架會主動的調用該組件中的相關方法,而采用BundleContext方法的話則需要自己主動監聽相應的事件。
          同樣是通過這樣簡單的兩步就可以實現模塊的可擴展性。

          這樣就產生了一個問題,既然是這樣,為什么還需要之前Eclipse的擴展點的設計呢?除了擴展點相比采用OSGi的Service的方法更加有語義之外,暫時還真沒想明白。

          posted on 2006-09-26 18:37 BlueDavy 閱讀(3799) 評論(3)  編輯  收藏 所屬分類: OSGi、SOA、SCA

          評論

          # re: 基于OSGi實現可擴展的模塊的設計 2006-11-08 15:13 生與夏花

          個人覺得這是一個組件之間的關系問題,組件之間的關系可以是依賴,可以是繼承關系。
          Extensions 和 Extension points 更多的應該應用在繼承方面.
          比如,像struts中的許多的struts-config文件就可以用擴展點的機制來實現,就可以做到動態加載struts配置了.
          DS還有bundleContext獲取服務的方法更多的應該用在依賴方面.
            回復  更多評論   

          # re: 基于OSGi實現可擴展的模塊的設計 2006-12-04 14:23 心內求法

          估計eclipse延用擴展點的設計是為了向下兼容。  回復  更多評論   

          # re: 基于OSGi實現可擴展的模塊的設計[未登錄] 2009-11-03 09:16 harry

          Service導出API,Extension points導出SPI(Service provider interface)  回復  更多評論   

          公告

           









          feedsky
          抓蝦
          google reader
          鮮果

          導航

          <2006年9月>
          272829303112
          3456789
          10111213141516
          17181920212223
          24252627282930
          1234567

          統計

          隨筆分類

          隨筆檔案

          文章檔案

          Blogger's

          搜索

          最新評論

          閱讀排行榜

          評論排行榜

          主站蜘蛛池模板: 宜良县| 西和县| 贵阳市| 黑龙江省| 沅陵县| 永昌县| 荣昌县| 新余市| 左贡县| 大连市| 通河县| 汾西县| 宁明县| 蒲江县| 恩平市| 宿州市| 溧阳市| 新绛县| 元江| 瓮安县| 天门市| 庆元县| 广河县| 永兴县| 安平县| 大悟县| 博客| 朔州市| 广德县| 永善县| 虎林市| 柳江县| 运城市| 上饶县| 区。| 磐石市| 新巴尔虎左旗| 方正县| 杭锦后旗| 吉安市| 贺州市|