escout

          代碼、心情

          常用鏈接

          統(tǒng)計

          SOA相關(guān)

          我參與的團(tuán)隊

          最新評論

          SOA之SCA規(guī)范摘要及我的理解

          上次開會討論了對SCA和SDO的理解后,又重讀了IBM上關(guān)于SCA的文章,摘要如下:
          SCA(Service Component Architecture)編程模型入門上指出:
          ?
          服務(wù)組件(SCA Service Component)是SCA中的基本組成元素和基本構(gòu)建單位,也是我們具體實現(xiàn)業(yè)務(wù)邏輯的地方。
          其組件結(jié)構(gòu)圖如下:

          ?????? 服務(wù)模塊(Service Module)由一個或多個具有內(nèi)在業(yè)務(wù)聯(lián)系的服務(wù)組件構(gòu)成,模塊是SCA中的運行單位,因為一個SCA模塊背后對應(yīng)的是一個J2EE的企業(yè)應(yīng)用項目。
          服務(wù)模塊之間的關(guān)系如下:

          ?????? 可見,同一服務(wù)模塊內(nèi)部的服務(wù)組件之間是通過Reference和Interface直接關(guān)聯(lián)起來的,相對來說有比較緊密地耦合。
          結(jié)合HelloWorld的示例應(yīng)用

          ?????? 可以看到,同一個ServiceModule實際上實現(xiàn)了一個獨立的應(yīng)用,這個應(yīng)用一般有自己的展示層,通過Standalone Reference的方式,和Service Component建立聯(lián)系,實際的業(yè)務(wù)邏輯都封裝在Service Component中。同時,對于不同的ServiceModule,要相互引用,就要多費一些功夫了,需要使用服務(wù)模塊中的導(dǎo)入和導(dǎo)出定位到實際的服務(wù)模塊。
          ?????? 對于不同ServiceModule的交互,文章WebSphere Process Server V6 體系結(jié)構(gòu)概述中給出下圖一個簡單的端到端業(yè)務(wù)數(shù)據(jù)同步的例子:

          并解釋:
          ?????? 源EIS通過其適配器發(fā)出請求,傳入一個應(yīng)用特定業(yè)務(wù)對象(Application-Specific Business Object,ASBO),通過轉(zhuǎn)接器轉(zhuǎn)換成一般業(yè)務(wù)對象(Generic Business Object,GBO),進(jìn)入業(yè)務(wù)流程引擎進(jìn)行處理,處理的結(jié)果以另一個GBO的形式,通過Selector傳輸?shù)街付ǖ哪繕?biāo),再經(jīng)轉(zhuǎn)接器轉(zhuǎn)換為目標(biāo)EIS的應(yīng)用特定業(yè)務(wù)對象,進(jìn)入目標(biāo)EIS進(jìn)行處理。
          ?????? 其中中間的矩形包括的ASBO、轉(zhuǎn)換器、GBO等等,按照我的理解,我覺得應(yīng)該是企業(yè)服務(wù)總線ESB的功能,也就是不同的ServiceModule都插接到ESB上,通過業(yè)務(wù)對象映射服務(wù)(Map Service)以及關(guān)系服務(wù)(Relationship Service)一起,完成接口轉(zhuǎn)接的功能。同時,在一個SCA Service Component中,一般都是使用同樣的BO,如果不同,可以使用SCA接口轉(zhuǎn)接器(Interface Mediator)提供了SCA接口轉(zhuǎn)接的功能轉(zhuǎn)換,但是考慮到BPEL等等的自動編排,一般ServiceModule內(nèi)部還是應(yīng)該使用同樣的BO,不同的ServiceModule之間一般BO不同。這里的BO就是SDO
          同時,可以看到,不同模塊的耦合主要是通過引用來實現(xiàn),一般來說,SCA引用分為模塊內(nèi)的引用和模塊間的引用。模塊間的引用定義的是一個模塊(中的組件)對于外部服務(wù),例如另一個模塊中的組件或者Web服務(wù)等的依賴。
          ??????同時,我們注意到一點,在很多IBM SOA的文章中,都是使用了Service Locator的方法來定位服務(wù),比如SCA(Service Component Architecture)編程模型入門中就使用了如下代碼:
          1ServiceManager?serviceManager?=?new?ServiceManager();
          2Service?service?=?(Service)?serviceManager.locateService("HelloWorldInterfacePartner");
          ????注意到這里的HelloWorldInterfacePartner實際上是一個服務(wù)的邏輯名,所以這里就實際上解除了和實際的服務(wù)的耦合,是很松散的耦合。比較一下在spring等等IOC框架中的通過配置文件來組裝POJO的方法,這樣也不失為一種可行的策略。不過,相比而言,我還是更喜歡在spring中那種通過xml配置文件組裝bean的方法,更加靈活一些的

          posted on 2006-05-27 00:26 綠色使者、綠色心情 閱讀(1545) 評論(3)  編輯  收藏 所屬分類: soa team

          評論

          # re: SOA之SCA規(guī)范摘要及我的理解 2006-05-27 20:02 突突

          通過轉(zhuǎn)接器轉(zhuǎn)換成一般業(yè)務(wù)對象(Generic Business Object,GBO),進(jìn)入業(yè)務(wù)流程引擎進(jìn)行處理,處理的結(jié)果以另一個GBO的形式,這里的BO就是SDO

          對象傳來傳去, 感覺好復(fù)雜.   回復(fù)  更多評論   

          # re: SOA之SCA規(guī)范摘要及我的理解 2006-05-28 07:15 Richie

          同時,我們注意到一點,在很多IBM SOA的文章中,都是使用了Service Locator的方法來定位服務(wù),比如SCA(Service Component Architecture)編程模型入門中就使用了如下代碼:
          1ServiceManager serviceManager = new ServiceManager();
          2Service service = (Service) serviceManager.locateService("HelloWorldInterfacePartner");

          服務(wù)定位模式,并不太好與IOC相并論,可測試性會有很大損害.EJB2.x中的jndi查找也可理解為這種模式的一個實現(xiàn)。  回復(fù)  更多評論   

          # re: SOA之SCA規(guī)范摘要及我的理解 2006-05-28 09:45 綠色使者、綠色心情

          我覺得恰恰是使用IOC,會使可測試性更好,因為這樣可以脫離開容器測試,并在測試時替換實現(xiàn)。必須在容器內(nèi)測試是自動化的可測試性的大敵,同時嚴(yán)重影響測試效率。EJB2.x中的測試也是最被人詬病之一,其中必須依賴jndi查找應(yīng)該是一個主要原因  回復(fù)  更多評論   

          主站蜘蛛池模板: 青田县| 潼关县| 泌阳县| 旬阳县| 嘉义市| 六安市| 镇宁| 琼中| 罗源县| 兰考县| 凤翔县| 新竹市| 台安县| 嵊州市| 民县| 乌拉特中旗| 霍邱县| 额尔古纳市| 铁岭县| 永登县| 夏邑县| 稷山县| 中超| 洪江市| 苗栗县| 崇左市| 清流县| 陕西省| 长治县| 田林县| 天峻县| 松原市| 贵阳市| 清水河县| 措美县| 邯郸市| 缙云县| 德州市| 湛江市| 仙桃市| 三台县|