服務接口+版本+屬性注冊/查找機制

          在使用Spring的時候,我們習慣于用bean的名稱作為注冊、查找的條件,這也就意味著bean的引用是唯一的了,而不能來查找、注入一系列具備相同功能但不同實現的bean,這種應用的場景其實還是很多的,尤其在擴展的場景中,在這篇blog中以一個應用場景來說明下這種需求,順便也宣傳下OSGi的服務接口+版本+屬性的注冊和查找機制。
          以將Spring bean發布為DSF服務的bean來講,這個bean需要做到根據發布DSF服務的方式,調用相應的具體發布DSF服務的實現bean,同時要做到的自然是在以后增加了新的發布方式后,不需要修改這個bean的代碼。
          要實現這個需求,首先想到的是這樣的解決方案:
          1、在這個bean中直接注入所有的發布DSF服務實現的bean,在調用的時候可以根據規則尋找到相應的bean,這個在Spring中能夠實現的方式也許是這樣:
                <bean id="DSFServiceExporterFactory" class="將Spring bean發布為DSF服務的bean">
                        <property name="exporterClassMap">
                               <map>
                                             <entry key="jndi"><ref bean="以JNDI方式發布DSF服務端的bean"></entry>
                                             <entry key="webservice"><ref bean="以Webservice方式發布DSF服務端的bean"></entry>
                               </map>
                        </property>
                </bean>

                這是一種實現方式了,這樣當以后增加了新的發布方式后,通過增加bean的定義以及修改這里map里面的東西就可以了。
          2、第二種實現方法就很常見了,就是寫個properties文件,配置各種發布方式具體對應的實現類。
          但這兩種方法都不夠的優雅,它們都有個共同的特點,就是需要去維護一個共同的配置的地方,想象中最好的解決方法是類似這樣的配置:
          <bean id="DSFServiceExporterFactory" class="將Spring bean發布為DSF服務的bean">
                        <property name="exporterClasses">
                                <ref bean="cn.bluedavy.dsf.exporter.*">                     
                        </property>
          </bean>
          這樣就把所有的cn.bluedavy.dsf.exporter.開頭的bean都注入到exporterClasses里了,當然,在根據具體的協議查找實現類時,又得提供一種支持方法了,好,不再去自己瞎琢磨了,來看看如果是OSGi的服務模型的話,會怎么樣去實現這樣的東西:
          在OSGi中每個對外提供的service都以接口來定義,在上面的場景中,很明顯,自然會出現的一個現象就是如果多個服務實現同樣的接口的話怎么去找到自己要的那個服務呢,OSGi中多數采用的方法是為這個服務加上一個屬性標識,在查找服務時就可以通過接口,再加上屬性標識來查找到想要的服務了,又或者可以只查找接口,獲取到所有實現這類接口的服務。
          按照這樣的模型的話上面的場景就很容易實現了,寫個模擬的配置文件:
          <osgi:reference id="exporterClasses" interface="cn.bluedavy.dsf.exporter.DSFExporter"/>
          <bean id="DSFServiceExporterFactory" class="將Spring bean發布為DSF服務的bean">
                        <property name="exporterClasses">
                                <ref bean="exporterClasses">                     
                        </property>
          </bean>
          這個和真實的會有些不同,但意思是差不多的,:),而OSGi的服務呢,在注入后可以直接通過ServiceReference這個對象來獲取到這個服務的相關屬性信息,這樣其實也就可以做到類似之前第一個解決方案的效果,但同時又解決了不需要維護統一文件的問題。
          服務模型的這種語義性質的機制使得服務的概念表達得更為清楚,使用得也更為方便了,以接口來表達服務的功能是一種非常合理的方式,同時輔以屬性來描述實現此功能的方式(有點像元數據里的keyword)無疑更加全面的表達了此服務, 也使得使用者能夠更合理的選擇需要的服務實現。
          版本機制在這篇blog中沒有提及,這個我想在實際的過程中大家應該都深受版本混淆的痛苦了,:),在這里不多描述了,服務模型目的無疑就是為了更加清晰的表達一個功能,并且讓使用者更加方便的查找、使用所需要的功能。

          posted on 2008-02-13 18:00 BlueDavy 閱讀(3591) 評論(1)  編輯  收藏 所屬分類: OSGi、SOA、SCA

          評論

          # re: 服務接口+版本+屬性注冊/查找機制 2008-02-17 12:29 51dluu

          非常不錯的想法。。  回復  更多評論   

          公告

           









          feedsky
          抓蝦
          google reader
          鮮果

          導航

          <2008年2月>
          272829303112
          3456789
          10111213141516
          17181920212223
          2425262728291
          2345678

          統計

          隨筆分類

          隨筆檔案

          文章檔案

          Blogger's

          搜索

          最新評論

          閱讀排行榜

          評論排行榜

          主站蜘蛛池模板: 基隆市| 绥化市| 色达县| 台南市| 扎囊县| 海宁市| 肇源县| 阿尔山市| 普格县| 综艺| 四会市| 山西省| 冀州市| 思茅市| 盐池县| 阜新市| 泉州市| 巴林左旗| 连云港市| 中阳县| 大荔县| 犍为县| 永丰县| 交城县| 盐津县| 如东县| 海兴县| 虎林市| 壤塘县| 时尚| 康马县| 扎赉特旗| 阿合奇县| 田林县| 元江| 安新县| 乐安县| 保靖县| 绥德县| 鄯善县| 华亭县|