Soa+概念和思想.ppt_第1頁(yè)
Soa+概念和思想.ppt_第2頁(yè)
Soa+概念和思想.ppt_第3頁(yè)
Soa+概念和思想.ppt_第4頁(yè)
Soa+概念和思想.ppt_第5頁(yè)
已閱讀5頁(yè),還剩18頁(yè)未讀 繼續(xù)免費(fèi)閱讀

下載本文檔

版權(quán)說(shuō)明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)

文檔簡(jiǎn)介

SOA概念和思想,中央軟件部總體技術(shù)部2008-02-18,2,目錄,3,軟件設(shè)計(jì)的發(fā)展歷程,面向過(guò)程的編程:以C語(yǔ)言為最典型的代表,是一種緊密耦合的軟件設(shè)計(jì)技術(shù),面向?qū)ο蟮木幊蹋簩⒚嫦蜻^(guò)程相關(guān)的函數(shù)封裝起來(lái),消除全局變量,使用接口對(duì)外提供具體功能,形成能夠獨(dú)立調(diào)用的對(duì)象,實(shí)現(xiàn)對(duì)象可重用,可擴(kuò)展,可繼承。,面向組件的編程:對(duì)面向?qū)ο蟪绦蜻M(jìn)一步封裝,提供實(shí)現(xiàn)遠(yuǎn)程調(diào)用的接口和位置透明的能力,如Jee/Corba/.Net平臺(tái)。但他們有一共同的缺點(diǎn),實(shí)現(xiàn)技術(shù)的不透明性。,面向服務(wù)的編程:在面向組件編程的基礎(chǔ)上,進(jìn)一步提供粗力度,松耦合以及技術(shù)透明的組件,從而提高系統(tǒng)的擴(kuò)展性和重用性。,4,什么是SOA,SOA是一個(gè)Diagram,不是一個(gè)具體的架構(gòu),就像經(jīng)常說(shuō)的OOD一樣,描述的是一組設(shè)計(jì)原則,什么是設(shè)計(jì)原則:Representsahighlyrecommendedguidelineforshapingsolutionlogicinacertainway,看看OOD中的例子:?jiǎn)我回?zé)任原則(SRP)開閉原則(OCP)替換原則(LSP)依賴倒置原則(DIP)等等。,SOA也定義了類似的原則,5,驅(qū)動(dòng)SOA的動(dòng)力,SOA的重點(diǎn)就是找出解決上述問題的方法,6,服務(wù)的概念,Aservicecanessentiallyactasacontainerofrelatedcapabilities.Itiscomprisedofabodyoflogicdesignedtocarryoutthesecapabilitiesandaservicecontractthatexpresseswhichofitscapabilitiesaremadeavailableforpublicinvocation,舉例子:ATM取款機(jī)服務(wù)所包含的capabilities1.取款功能2.余額查詢功能3.存款功能,7,服務(wù)契約,Acontractforaserviceestablishesthetermsofengagement,providingtechnicalconstraintsandrequirementsaswellasanysemanticinformationtheserviceownerwishestomakepublic.,主要包含四個(gè)部分:1.功能描述(定義business驅(qū)動(dòng)的接口而不是technical驅(qū)動(dòng)的接口)2.使用這些功能所需要的交互的數(shù)據(jù)信息的描述3.策略信息(技術(shù)約束、QOS等)4.其他非技術(shù)文檔(SLA等),8,服務(wù)契約,Acontractforaserviceestablishesthetermsofengagement,providingtechnicalconstraintsandrequirementsaswellasanysemanticinformationtheserviceownerwishestomakepublic.,9,服務(wù)耦合,LogictoContract耦合:先設(shè)計(jì)物理契約,然后再實(shí)現(xiàn)底層的邏輯導(dǎo)致從實(shí)現(xiàn)邏輯到契約之間的單向的緊耦合這是一個(gè)正面的設(shè)計(jì)方式,ContracttoLogic耦合:現(xiàn)有底層的實(shí)現(xiàn)邏輯,而后推導(dǎo)出最終的物理契約導(dǎo)致從契約到實(shí)現(xiàn)邏輯之間的單向的緊耦合這是一個(gè)負(fù)面的設(shè)計(jì)方式,ContracttoTechnology耦合物理契約本身的設(shè)計(jì),暴露了實(shí)現(xiàn)邏輯所使用的技術(shù)細(xì)節(jié)導(dǎo)致從契約到實(shí)現(xiàn)邏輯之間的單向的緊耦合這是一個(gè)負(fù)面的設(shè)計(jì)方式,ContracttoImplementation耦合物理契約的設(shè)計(jì),暴露了實(shí)現(xiàn)邏輯內(nèi)部的數(shù)據(jù)模型和數(shù)據(jù)結(jié)構(gòu)這是一個(gè)負(fù)面的設(shè)計(jì)方式,10,服務(wù)消費(fèi)者耦合,Consumer-to-ImplementationCoupling耦合:消費(fèi)者繞過(guò)契約,直接訪問服務(wù)的實(shí)現(xiàn)邏輯這是一個(gè)負(fù)面的設(shè)計(jì)方式,Consumer-to-ContractCoupling耦合:消費(fèi)者通過(guò)契約來(lái)訪問服務(wù)這是一個(gè)正面的設(shè)計(jì)方式,但是服務(wù)和契約之間的耦合最終會(huì)導(dǎo)致消費(fèi)者和服務(wù)之間的耦合:,11,服務(wù)重用,LogictoContract耦合,ContracttoLogic耦合,ContracttoTechnology耦合,ContracttoImplementation耦合,12,服務(wù)抽象,為什么抽象是必須的:1.容易導(dǎo)致ContracttoImplementation耦合2.降低了服務(wù)自己升級(jí)、演化的能力,服務(wù)抽象的幾個(gè)方面:1.TechnologyInformation(技術(shù)實(shí)現(xiàn)和底層邏輯)2.FunctionalInformation(功能接口)3.ProgrammaticLogicInformation()4.QualityofServiceInformation(服務(wù)的行為和約束),13,服務(wù)抽象,為什么抽象是必須的:1.容易導(dǎo)致ContracttoImplementation耦合2.降低了服務(wù)自己升級(jí)、演化的能力,服務(wù)抽象的幾個(gè)方面:1.TechnologyInformation(技術(shù)實(shí)現(xiàn)和底層邏輯)2.FunctionalInformation(功能接口)3.ProgrammaticLogicInformation(實(shí)現(xiàn)邏輯,算法)4.QualityofServiceInformation(服務(wù)的行為和約束),14,服務(wù)無(wú)狀態(tài)性,盡可能利用各種手段,ContracttoLogic耦合,ContracttoTechnology耦合,ContracttoImplementation耦合,15,服務(wù)自治,自治的本意:一個(gè)系統(tǒng)能夠自我決定自己的行為、演化而不受外部的因素的制約的能力;,服務(wù)自治所帶來(lái)的兩個(gè)好處:1.系統(tǒng)行為的可預(yù)見性2.系統(tǒng)的可靠性,兩種主要的服務(wù)自治類型:1.運(yùn)行時(shí):在運(yùn)行情況下,服務(wù)控制自己邏輯的能力持續(xù)的執(zhí)行性能高度的可靠性行為的可預(yù)見性2.設(shè)計(jì)時(shí):設(shè)計(jì)系統(tǒng)時(shí)的關(guān)注點(diǎn)服務(wù)是否能夠自由的升級(jí)、變更,Thegreatertheamountofdesign-timeautonomy,thegreatertheamountofattainableruntimeautonomy,16,服務(wù)自治,17,服務(wù)可發(fā)現(xiàn)性,LogictoContract耦合,ContracttoLogic耦合,Contractt

溫馨提示

  • 1. 本站所有資源如無(wú)特殊說(shuō)明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁(yè)內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
  • 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 人人文庫(kù)網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
  • 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。

評(píng)論

0/150

提交評(píng)論