1 SOA
AOA是一個(gè)組件模型,將應(yīng)用的不同功能單元通過(guò)服務(wù)之間定義良好的接口和契約聯(lián)系起來(lái)。服務(wù)接口獨(dú)立于實(shí)現(xiàn)服務(wù)的硬件平臺(tái)、操作系統(tǒng)和編程語(yǔ)言。系統(tǒng)包含的服務(wù)以一種通用和一致的方式進(jìn)行交互,使系統(tǒng)集成不必關(guān)注底層的實(shí)現(xiàn)細(xì)節(jié)。SOA具有以下基本特點(diǎn):
(1)面向服務(wù)。SOA以服務(wù)作為關(guān)注的重點(diǎn),支持面向服務(wù)的開(kāi)發(fā)方法。服務(wù)從更高的抽象層次上定義,與業(yè)務(wù)相對(duì)應(yīng),可通過(guò)面向過(guò)程、面向消息、面向?qū)ο蟮确椒▉?lái)實(shí)現(xiàn)。
(2)松耦合。SOA強(qiáng)調(diào)服務(wù)間是松耦合的,包括了三層含義:一是接口松耦合,即服務(wù)接口封裝了所有的實(shí)現(xiàn)細(xì)節(jié),對(duì)服務(wù)請(qǐng)求者屏蔽實(shí)現(xiàn)細(xì)節(jié);二是技術(shù)松耦合,指服務(wù)請(qǐng)求者和服務(wù)提供者的實(shí)現(xiàn)和運(yùn)行不需要依賴(lài)特定的技術(shù);三是流程松耦合,指服務(wù)不與特定的業(yè)務(wù)流程相關(guān),能夠重用于不同的業(yè)務(wù)中。
(3)靈活性。在SOA的應(yīng)用系統(tǒng)中服務(wù)是實(shí)現(xiàn)功能的基本單位。服務(wù)的可重用性和重組服務(wù)提高了業(yè)務(wù)的靈活性。
(4)標(biāo)準(zhǔn)化。SOA應(yīng)用系統(tǒng)中的服務(wù)應(yīng)盡量支持開(kāi)放的標(biāo)準(zhǔn),通過(guò)標(biāo)準(zhǔn)化提高互操作性。
2 云計(jì)算
目前關(guān)于云計(jì)算沒(méi)有統(tǒng)一的定義。IBM給出的定義是:云計(jì)算是一種通過(guò)虛擬化的方式共享資源的計(jì)算,計(jì)算資源可以動(dòng)態(tài)部署、動(dòng)態(tài)調(diào)度、動(dòng)態(tài)回收。云計(jì)算被視為一種計(jì)算模式,通過(guò)基于互聯(lián)網(wǎng)連接的服務(wù)集合完成計(jì)算任務(wù)。云計(jì)算保證服務(wù)和數(shù)據(jù)在整個(gè)云中都可用,使得用戶(hù)能夠以較低的成本隨時(shí)接入訪問(wèn)數(shù)據(jù),提供了集成、共享的公共平臺(tái)。云計(jì)算可以劃分為3種服務(wù)模型:
(1)基礎(chǔ)架構(gòu)即服務(wù)(IaaS)。指的是將服務(wù)器、存儲(chǔ)和網(wǎng)絡(luò)等底層設(shè)施作為服務(wù)提供給用戶(hù)。IaaS一般按照需求利用服務(wù)器、連接、存儲(chǔ)以及相關(guān)的必要工具構(gòu)建應(yīng)用環(huán)境。因此用戶(hù)可以通過(guò)動(dòng)態(tài)申請(qǐng)資源構(gòu)建云應(yīng)用。IaaS相對(duì)于軟件的使用要更為困難,不過(guò)卻為應(yīng)用提供了更好的靈活性。
(2)平臺(tái)即服務(wù)(PaaS)。指的是一種易于配置的軟件平臺(tái)。這種平臺(tái)一般包含數(shù)據(jù)庫(kù)、中間件及開(kāi)發(fā)工具,均以服務(wù)形式通過(guò)互聯(lián)網(wǎng)提供給第三方開(kāi)發(fā)人員。開(kāi)發(fā)人員可以通過(guò)PaaS部署應(yīng)用,不用在意系統(tǒng)的管理細(xì)節(jié)。PaaS的典型應(yīng)用是Google App Engine2,包括了完整的Python應(yīng)用環(huán)境。通常PaaS可以包含于IaaS中,與IaaS相比更為好用,但不夠靈活。
(3)軟件即服務(wù)(SaaS)。指的是通過(guò)網(wǎng)絡(luò)將應(yīng)用程序以服務(wù)形式提供給用戶(hù)。其中應(yīng)用程序可以是公有云提供商提供的商用SaaS應(yīng)用,或企業(yè)專(zhuān)用云提供的商用或訂制的SaaS應(yīng)用。SaaS的供應(yīng)商基于多租戶(hù)的體系架構(gòu)為客戶(hù)提供軟件服務(wù)。
3 SOA與云計(jì)算的集成
3.1 SOA與云計(jì)算的比較
SOA與云計(jì)算在很多方面都有重疊,其中最為重要的交叉點(diǎn)是面向服務(wù)的概念。云計(jì)算關(guān)注的焦點(diǎn)是將計(jì)算當(dāng)成可以買(mǎi)賣(mài)的商品,比如大規(guī)模在線存儲(chǔ)、網(wǎng)絡(luò)應(yīng)用平臺(tái)等。云計(jì)算提供的服務(wù)非常廣泛,包括了從硬件層次到應(yīng)用層軟件。而SOA一般提供象Web Service應(yīng)用這樣的服務(wù)。SOA與云計(jì)算都非常依賴(lài)網(wǎng)絡(luò),這也是它們共同的缺陷。
雖然SOA與云計(jì)算有很多共同點(diǎn),但是它們有不同的側(cè)重點(diǎn)。SOA實(shí)現(xiàn)是系統(tǒng)與系統(tǒng)之問(wèn)進(jìn)行集成的技術(shù),允許通過(guò)不同的部署語(yǔ)言和平臺(tái)進(jìn)行系統(tǒng)集成。基于SOA實(shí)現(xiàn)的系統(tǒng)接口一致性能夠降低集成的開(kāi)銷(xiāo),提高系統(tǒng)的敏捷性。云計(jì)算的重點(diǎn)是利用網(wǎng)絡(luò)購(gòu)買(mǎi)需要的功能,允許市場(chǎng)以商品的形式提供各種功能,避免了用戶(hù)花費(fèi)過(guò)多成本實(shí)現(xiàn)所需功能。在公共標(biāo)準(zhǔn)方面SOA和云計(jì)算發(fā)展的階段存在差異。SOA的軟件服務(wù)實(shí)現(xiàn)已有成熟的標(biāo)準(zhǔn),比如WSDL、SOAP等。云計(jì)算還沒(méi)有形成成熟的標(biāo)準(zhǔn),不同的服務(wù)供應(yīng)商之間達(dá)成一致還比較困難。SOA與云計(jì)算的關(guān)系是一種互補(bǔ)的關(guān)系。云計(jì)算和SOA的供應(yīng)商可以互相借鑒和學(xué)習(xí)。云計(jì)算中服務(wù)的設(shè)計(jì)和服務(wù)的擴(kuò)展性都是值得SOA借鑒的。而SOA中的服務(wù)治理和架構(gòu)驅(qū)動(dòng)是云計(jì)算值得學(xué)習(xí)的地方。
3.2 SOA與云計(jì)算的集成方法
由于在SOA發(fā)展的早期一些企業(yè)沒(méi)有從SOA的投資中收益,很多企業(yè)對(duì)SOA產(chǎn)生了懷疑。經(jīng)過(guò)一段時(shí)間的思考,人們對(duì)SOA的理解回歸理性,對(duì)SOA的應(yīng)用場(chǎng)景有了更為準(zhǔn)確的定位。云計(jì)算的出現(xiàn)為SOA提供了新的發(fā)展起點(diǎn),將SOA與云計(jì)算結(jié)合在一起運(yùn)用于企業(yè)的信息化是當(dāng)前推進(jìn)兩者發(fā)展實(shí)現(xiàn)雙贏的有效途徑。本文提出從以下幾個(gè)方面進(jìn)行SOA與云計(jì)算的集成。
(1)建立配套的規(guī)范標(biāo)準(zhǔn)。目前SOA和云計(jì)算都不是十分成熟,二者在標(biāo)準(zhǔn)化方面也有顯著差異。S0A在標(biāo)準(zhǔn)化方面已經(jīng)走到了前面,已經(jīng)有了一系列的規(guī)范,而云計(jì)算還處于各方各自為戰(zhàn)的局面。由于SOA和云計(jì)算最大的共同點(diǎn)就是服務(wù),在服務(wù)方面也應(yīng)該建立統(tǒng)一的標(biāo)準(zhǔn),使得SOA可以通過(guò)云計(jì)算對(duì)外提供服務(wù)。另外SOA還可以根據(jù)服務(wù)的粒度采用云計(jì)算的服務(wù)進(jìn)行新的服務(wù)組合。
(2)提供高可用的服務(wù)。云計(jì)算中運(yùn)維工作由云服務(wù)提供商和虛擬化等技術(shù)承擔(dān),而可伸縮性也導(dǎo)致云計(jì)算的用戶(hù)在一定程度上失去了對(duì)資源的控制權(quán)。在云計(jì)算中服務(wù)出現(xiàn)故障或者供應(yīng)商出現(xiàn)問(wèn)題時(shí),云計(jì)算的用戶(hù)就面臨應(yīng)用無(wú)法使用的問(wèn)題。使用SOA實(shí)現(xiàn)應(yīng)用系統(tǒng)的組件化和服務(wù)化是解決這一問(wèn)題的措施之一。在基于SOA構(gòu)建應(yīng)用系統(tǒng)時(shí),將應(yīng)用功能細(xì)分為細(xì)粒度、無(wú)狀態(tài)的組件,然后將其封裝為服務(wù),將同一服務(wù)的不同實(shí)例分散到多個(gè)實(shí)例中運(yùn)行,從而提高服務(wù)的可用性。在云計(jì)算環(huán)境中,使用中的云服務(wù)是不可控的。這就需要在架構(gòu)設(shè)計(jì)時(shí)充分了解云服務(wù)的可用性。為了提供高可用的服務(wù),在云計(jì)算標(biāo)準(zhǔn)化之后,還可以使用多個(gè)云服務(wù)提供商提供服務(wù)來(lái)實(shí)現(xiàn)高可用。
(3)改進(jìn)服務(wù)發(fā)現(xiàn)。服務(wù)發(fā)現(xiàn)是SOA中必不可少的功能,它幫助將經(jīng)過(guò)注冊(cè)的服務(wù)提供給用戶(hù)使用。在云計(jì)算中與SOA類(lèi)似,也需要服務(wù)發(fā)現(xiàn)功能的支持。與SOA不同的是,云計(jì)算中采取的是付費(fèi)訂購(gòu)模式,需要用戶(hù)申購(gòu)才能使用需要的服務(wù)。結(jié)合SOA的服務(wù)發(fā)現(xiàn)技術(shù),云計(jì)算中可以改進(jìn)服務(wù)發(fā)現(xiàn)機(jī)制,支持用戶(hù)從數(shù)量龐大的服務(wù)中進(jìn)行選購(gòu)。
(4)完善服務(wù)治理和管理功能。服務(wù)的治理或管理對(duì)SOA的成功實(shí)施非常重要。在SOA的發(fā)展中,治理技術(shù)已經(jīng)積累了一定的基礎(chǔ)。而云計(jì)算中幾乎沒(méi)有任何治理的思想,也沒(méi)有云計(jì)算控制和執(zhí)行策略,對(duì)云計(jì)算在企業(yè)中的應(yīng)用起到了阻礙作用。云計(jì)算中對(duì)服務(wù)進(jìn)行定價(jià)收費(fèi)也是服務(wù)治理的一個(gè)重要應(yīng)用場(chǎng)景。因此,利用SOA中的服務(wù)治理管理經(jīng)驗(yàn)來(lái)推動(dòng)云計(jì)算的發(fā)展,完善服務(wù)治理是SOA與云計(jì)算的有效結(jié)合點(diǎn)。
4 結(jié)語(yǔ)
云計(jì)算越來(lái)越受到企業(yè)的關(guān)注,已經(jīng)成為了最炙手可熱的瓶興技術(shù)。云計(jì)算的發(fā)展也為SOA帶來(lái)了新的活力,將二者結(jié)合運(yùn)用成為了企業(yè)可選的新的發(fā)展路線。本文提出的SOA與云計(jì)算集成的方法為企業(yè)更好運(yùn)用這兩種技術(shù)提供了參考。
核心關(guān)注:拓步ERP系統(tǒng)平臺(tái)是覆蓋了眾多的業(yè)務(wù)領(lǐng)域、行業(yè)應(yīng)用,蘊(yùn)涵了豐富的ERP管理思想,集成了ERP軟件業(yè)務(wù)管理理念,功能涉及供應(yīng)鏈、成本、制造、CRM、HR等眾多業(yè)務(wù)領(lǐng)域的管理,全面涵蓋了企業(yè)關(guān)注ERP管理系統(tǒng)的核心領(lǐng)域,是眾多中小企業(yè)信息化建設(shè)首選的ERP管理軟件信賴(lài)品牌。
轉(zhuǎn)載請(qǐng)注明出處:拓步ERP資訊網(wǎng)http://m.hanmeixuan.com/
本文標(biāo)題:SOA與云計(jì)算的集成探究
本文網(wǎng)址:http://m.hanmeixuan.com/html/consultation/1083978968.html