引用說明:原文來自于 http://www.ibm.com/developerworks/cn/webservices/1010_wanghq_eda/1010_wanghq_eda.html ? ,為了方便本人閱讀,文本格式略有調(diào)整。
?
EDA/SOA/ESB 的實(shí)踐摘要
?
事件驅(qū)動(dòng)架構(gòu) (Event-Driven Architecture,EDA)?
面向服務(wù)架構(gòu) (Service-Oriented Architecture, SOA) 是一種 IT 架構(gòu)策略,其基于面向服務(wù)的概念之上
企業(yè)服務(wù)總線(Enterprise Service Bus, ESB)
消息中間件(Message Oriented Middleware, MOM)
?
?
下圖是一個(gè)證券公司股票交易系統(tǒng)的簡(jiǎn)圖:
?
?
圖 1. 證券公司股票交易系統(tǒng)概略圖
?
從上圖我們可以看出,整個(gè)應(yīng)用被分為很多子系統(tǒng),各個(gè)子系統(tǒng)之間存在著大量的信息交互。而且大部分應(yīng)用輸入都需要經(jīng)歷一個(gè)比較長(zhǎng)的生命周 期,比如說一個(gè)客戶訂單輸入到系統(tǒng)后,會(huì)先后經(jīng)歷前臺(tái)系統(tǒng) (Front Office),中臺(tái)系統(tǒng) (Middle Office) 以及后臺(tái)系統(tǒng) (Back Office),而且每個(gè)系統(tǒng)內(nèi)部又包括很多服務(wù)組件。除了系統(tǒng)層面的跨度外, 這個(gè)生命周期也體現(xiàn)在時(shí)間長(zhǎng)度上。而且,如今所有的金融系統(tǒng)都追求 STP (Straight Through Processing) 的能力,主張盡可能少的人工干預(yù),這樣所有的服務(wù)組件都需要具備自觸發(fā)的能力。
?
?
我們需要一步步考慮整個(gè)架構(gòu)的實(shí)現(xiàn)途徑。首先面臨的就是一些基礎(chǔ)架構(gòu)的選擇。
?
基礎(chǔ)架構(gòu)的選擇
?
在這里我們需要回答一系列的問題:自己開發(fā)還是購(gòu)買?開源的還是商業(yè)的?選擇什么 Web Service 的基礎(chǔ)平臺(tái)?選擇什么樣的消息中間件(Message Oriented Middleware, MOM)?是否采用企業(yè)服務(wù)總線(Enterprise Service Bus, ESB)?這其中討論的最多的就是是否以及如何使用 ESB。個(gè)人觀點(diǎn),ESB 是有價(jià)值的,僅當(dāng)系統(tǒng)確實(shí)需要 ESB 的功能時(shí)。Accenture 首席技術(shù)官 Don Rippert 在他的一次早期訪談中提到發(fā)揮 SOA 的全部潛力大致需要以下 4 個(gè)步驟:
- 開始采用 SOA 架構(gòu),使用 XML 等標(biāo)準(zhǔn)的方式來使用應(yīng)用程序接口
- 捕獲一些業(yè)務(wù)過程,并將它們轉(zhuǎn)化為 Web 服務(wù)
- 引入并全面使用企業(yè)服務(wù)總線
- 將業(yè)務(wù)過程執(zhí)行語(yǔ)言(Business Process Execution Language, BPEL)集成進(jìn)來,利用業(yè)務(wù)過程建模工具和 BPEL 可以創(chuàng)建不同的應(yīng)用行為,而無需修改軟件
為什么將 ESB 的使用放在第三個(gè)步驟呢,那我們需要從 ESB 的定義入手,來了解 ESB 究竟帶給我們些什么。ESB 應(yīng)該被理解為模式而不是產(chǎn)品,它應(yīng)該至少具備以下這些功能:
- 服務(wù)的虛擬化,支持虛擬化通訊參與方之間的服務(wù)交互并對(duì)其進(jìn)行管理。意思就是服務(wù)只需要關(guān)注完成自己的功能,不需要關(guān)心哪個(gè)服務(wù)調(diào)用它以及它需要調(diào)用哪個(gè)服務(wù)。
- 服務(wù)的轉(zhuǎn)化、包裝以及橋接
- 消息的傳遞、過濾以及路由
- 服務(wù)編制(Orchestration)
基礎(chǔ)組件
?
在確定了系統(tǒng)的架構(gòu)后,我們需要著手來實(shí)現(xiàn)它。經(jīng)過這么多年的實(shí)踐,人們也總結(jié)出一些基礎(chǔ)的組件,這些組件對(duì)于事件驅(qū)動(dòng)的面向服務(wù)架構(gòu)來說是必不可少的,或者說經(jīng)常被使用到的。
- Web 服務(wù)基礎(chǔ)架構(gòu) (XML,SOAP,WSDL,UDDI 和 Quality of services)
- 企業(yè)服務(wù)總線(針對(duì)復(fù)雜應(yīng)用)
- 消息中間件
- 監(jiān)控體系
- 異常處理的討論
- 配置和規(guī)則引擎
其中第一、二項(xiàng)大家討論得最多,第三項(xiàng)也經(jīng)常被提及。作為消息運(yùn)轉(zhuǎn)的基礎(chǔ),消息中間件(Message-Oriented Middleware,MOM)必須做到安全、可靠和快捷。市面上有很多很成熟的產(chǎn)品,比如?WebSphere MQ,Apache ActiveMQ 等。而且還有些針對(duì)特定行業(yè)的特色化產(chǎn)品,比如 WebSphere MQ Low Latency Messaging 是一款專門針對(duì)金融行業(yè)的中間件,用來滿足高吞吐量、低延遲的業(yè)務(wù)需求。
?
成功部署SOA的七個(gè)步驟
?? ?第1步:盡職調(diào)查,做好你自己的功課
?? ?第2步:成立一個(gè)團(tuán)隊(duì)
?? ?第3步:制定現(xiàn)實(shí)的目標(biāo)
?? ?第4步:有效地管理你的數(shù)據(jù)
?? ?第5步:自己創(chuàng)建還是購(gòu)買SOA
?? ?第6步:循序漸進(jìn)
?? ?第7步:保持跟蹤
更多文章、技術(shù)交流、商務(wù)合作、聯(lián)系博主
微信掃碼或搜索:z360901061

微信掃一掃加我為好友
QQ號(hào)聯(lián)系: 360901061
您的支持是博主寫作最大的動(dòng)力,如果您喜歡我的文章,感覺我的文章對(duì)您有幫助,請(qǐng)用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點(diǎn)擊下面給點(diǎn)支持吧,站長(zhǎng)非常感激您!手機(jī)微信長(zhǎng)按不能支付解決辦法:請(qǐng)將微信支付二維碼保存到相冊(cè),切換到微信,然后點(diǎn)擊微信右上角掃一掃功能,選擇支付二維碼完成支付。
【本文對(duì)您有幫助就好】元
