WCF、Net remoting、Web service概念及區別

Windows通信基礎(Windows Communication Foundation,WCF)是基於Windows平臺下開發和部署服務的軟件開發包(Software Development Kit,SDK)。 WCF就是微軟對於分佈式處理的 編程技術的集大成者,它將DCOM、Remoting、Web Service、WSE、MSMQ集成在一起,從而降低了分佈式系統開發者的學習曲線,並統一了開發標準。 WCF

  

Windows通信基礎(Windows Communication Foundation,WCF)是基於Windows平臺下開發和部署服務的軟件開發包(Software Development Kit,SDK)。

  WCF就是微軟對於分佈式處理的 編程技術的集大成者,它將DCOM、Remoting、Web Service、WSE、MSMQ集成在一起,從而降低了分佈式系統開發者的學習曲線,並統一了開發標準。

 

WCF是建立在.Net Framework 2.0基礎之上的,包含在.NET 3.0/3.5當中。2005中並沒有包含WCF,但是當安裝好了WinFX Runtime Components後,我們就可以在Visual Studio 2005環境下開發和創建WCF的程序了。

  

  一 WCF

  概括地說,WCF具有如下的優勢:

  1、統一性

  前面已經敘述,WCF是對於ASMX,.Net Remoting,Enterprise Service,WSE,MSMQ等技術的整合。由於WCF完全是由託管代碼編寫,因此開發WCF的應用程序與開發其它的.Net應用程序沒有太大的區別,我們仍然可以像創建面向對象的應用程序那樣,利用WCF來創建面向服務的應用程序。

  2、互操作性

  由於WCF最基本的通信機制是SOAP,這就保證了系統之間的互操作性,即使是運行不同的上下文中。這種通信可以是基於.Net到.Net間的通信。

  可以跨進程、跨機器甚至於跨平臺的通信,只要支持標準的Web Service,例如J2EE應用服務器(如WebSphere,WebLogic)。應用程序可以運行在Windows操作系統下,也可以運行在其他的操作系統,如Sun Solaris,HP Unix,Linux等等。

  3、安全與可信賴

  WS-Security,WS-Trust和WS-SecureConversation均被添加到SOAP消息中,以用於用戶認證,數據完整性驗證,數據隱私等多種安全因素。

  在SOAP的header中增加了WS-ReliableMessaging允許可信賴的端對端通信。而建立在WS-Coordination 和WS-AtomicTransaction之上的基於SOAP格式交換的信息,則支持兩階段的事務提交(two-phase commit transactions)。

  上述的多種WS-Policy在WCF中都給與了支持。對於Messaging而言,SOAP是Web Service的基本協議,它包含了消息頭(header)和消息體(body)。在消息頭中,定義了WS-Addressing用於定位SOAP消息的地址信息,同時還包含了MTOM(消息傳輸優化機制,Message Transmission Optimization Mechanism)。

  4、兼容性

  WCF充分的考慮到了與舊有系統的兼容性。安裝WCF並不會影響原有的技術如ASMX和.Net Remoting。即使對於WCF和ASMX而言,雖然兩者都使用了SOAP,但基於WCF開發的應用程序,仍然可以直接與ASMX進行交互。 

  二 WebService的運行機理

  首先客戶端從服務器的到WebService的WSDL,同時在客戶端聲稱一個代理類(Proxy Class),這個代理類負責與WebService服務器進行Request 和Response,當一個數據(XML格式的)被封裝成SOAP格式的數據流發送到服務器端的時候,就會生成一個進程對象並且把接收到這個Request的SOAP包進行解析,然後對事物進行處理,處理結束以後再對這個計算結果進行SOAP包裝,然後把這個包作爲一個Response發送給客戶端的代理類(Proxy Class),同樣地,這個代理類也對這個SOAP包進行解析處理,繼而進行後續操作。

  三 .net Remoting

  是在DCOM等基礎上發展起來的一種技術,它的主要目的是實現跨平臺、跨語言、穿透企業防火牆,這也是他的基本特點,與WebService有所不同的是,它支持HTTP以及TCP信道,而且它不僅能傳輸XML格式的SOAP包,也可以傳輸傳統意義上的二進制流,這使得它變得效率更高也更加靈活。而且它不依賴於IIS,用戶可以自己開發(Development)並部署(Dispose)自己喜歡的宿主服務器,所以從這些方面上來講 WebService其實上是.netemoting的一種特例。

  區別:

  1、Remoting可以靈活的定義其所基於的協議,比如http,tcp等,如果定義爲HTTP,則與Web Service相同,但是webservice是無狀態的,使用remoting一般都喜歡定義爲TCP,這樣比Web Service稍爲高效一些,而且是有狀態的。

  2、Remoting不是標準,而Web Service是標準。

  3、Remoting一般需要通過一個WinForm或是Windows服務進行啓動,也可以使用iis部署,而Web Service則必須在IIS進行啓動。

  4、在VS.net開發環境中,專門對Web Service的調用進行了封裝,用起來比Remoting方便。

  5 net remoting只能應用於MS 的.net framework之下,需要客戶端必須安裝framework,但是WebService是平臺獨立的,跨語言(只要能支持XML的語言都可以) 以及穿透企業防火牆。

  分佈式應用程序設計:ASP.NET Web 服務和 .NET Remoting

  ASP.NET Web 服務偏向於 XML Schema 類型系統,提供具有廣泛使用範圍的跨平臺支持的簡單編程模型。.NET Remoting 偏向於運行時類型系統,提供較爲複雜而且使用範圍小得多的編程模型。這種本質上的差別是決定使用哪種技術的主要因素。但是,還要考慮很多其他設計因素,包括傳輸協議、主機進程、安全性、性能、狀態管理以及對事務的支持等。

  傳輸協議和主機進程

  儘管 SOAP 規範並不要求用 HTTP 作爲傳輸協議,但是客戶端只能通過 HTTP 訪問使用 ASP.NET Web 服務實現的 Web 服務,因爲它是 ASP.NET 支持的唯一一種傳輸協議。服務是通過 IIS 調用的,並在 ASP.NET 的輔助進程 aspnet_wp.exe 中執行。

  .NET Remoting 使您能夠在任何類型的應用程序(包括 Windows 窗體、託管的 Windows 服務、控制檯應用程序或 ASP.NET 輔助進程)中靈活地託管遠程對象。正如前面所述,.NET Remoting 提供兩個傳輸信道——TCP 和 HTTP。這兩個信道都能使用套接字提供任意發送和接收進程之間的通信。

  它還能將 HTTP 信道與 IIS 和 ASP.NET 輔助進程集成。這一點很重要,原因有以下幾點。首先,它是當客戶端請求到達時自動啓動 .NET Remoting 端點的唯一方法。.NET Remoting 管線不包括啓動遠程服務器所需的 DCOM 類型的服務控制管理器 (SCM)。如果從任意進程中提供遠程對象,則需要確保那些進程正在運行。還必須確保它們是線程安全的,例如,線程 A 不能在線程 B 開始關閉進程之後激活對象。如果從 ASP.NET 提供遠程對象,則可以利用 Aspnet_wp.exe 輔助進程,這樣既可自動啓動又具有線程安全的優勢。第二,與 IIS 集成是確保跨進程 .NET Remoting 調用的唯一途徑,如下一節所述。

  ASP.NET Web 服務和 .NET Remoting 基礎結構都是可擴展的。您可以過濾入站和出站消息,從多方面控制類型封送和元數據的生成。使用 .NET Remoting,還能實現您自己的格式化程序和信道。

  安全性

  由於 ASP.NET Web 服務依賴於 HTTP,因此它們與標準的 Internet 安全性基礎結構相集成。ASP.NET 利用 IIS 的安全性功能,爲標準 HTTP 驗證方案(包括基本、簡要、數字證書,甚至 Microsoft? .NET Passport)提供了強有力的支持。(還可以使用 Windows 集成驗證,但只能用於信任域中的客戶端。)使用可用的 HTTP 驗證方案的一個優勢在於,無需在 Web 服務中更改代碼,IIS 是在 ASP.NET Web 服務被調用之前執行驗證的。ASP.NET 還支持基於 .NET Passport 的驗證和其他自定義的驗證方案。ASP.NET 支持基於目標 URL 的訪問控制,並通過與 .NET 代碼訪問安全性 (CAS) 基礎結構的集成支持訪問控制。SSL 可用於確保通信的安全。

  儘管這些標準傳輸技術對於確保 Web 服務相當有效,但它們只能做到這種程度。在涉及到不同信任域中多個 Web 服務的複雜情況下,還得建立自定義的特殊解決方案。Microsoft 和其他公司正致力於創建一套安全性規範,該規範將基於 SOAP 消息的可擴展性提供消息級別的安全性功能。這些規範之一是 XML Web 服務安全性語言(WS-Security),它爲消息級別的憑據傳輸、消息完整性和消息保密定義了框架。

  正如上一節所述,一般情況下,.NET Remoting 管線不能確保跨進程調用的安全。使用 ASP.NET 託管於 IIS 中的 .NET Remoting 端點可以利用 ASP.NET Web 服務可用的所有安全性功能,包括對使用 SSL 確保有線通信的安全性的支持。如果您正在使用託管在進程中的 TCP 信道或 HTTP 信道(而不是 aspnet_wp.exe),則必須自己執行身份驗證、授權和保密機制。

  另一個要關注的安全性問題是,在不必更改默認安全性策略的情況下,從不完全信任的環境中執行代碼的能力。ASP.NET Web 服務客戶端代理可以在這些環境中工作,但 .NET Remoting 代理則不能。要從不完全信任的環境中使用 .NET Remoting 代理,需要特殊的序列化權限。默認情況下,該權限不會授予從 Intranet 或 Internet 上下載的代碼。如果要在不完全信任的環境中使用 .NET Remoting 客戶端,則需要更改從那些區域中加載的代碼的默認安全性策略。當您從運行於沙箱(如下載的 Windows 窗體應用程序)中的客戶端連接到系統時,ASP.NET Web 服務是較簡單的選擇,因爲不需要更改安全性策略。

  狀態管理

  默認情況下,ASP.NET Web 服務模型採用無狀態的服務結構;它並不是本能地與來自同一個用戶的多個調用相關。另外,客戶端每次調用 ASP.NET Web 服務時,都創建一個新的對象以服務於該請求。方法調用完成後,該對象即被破壞。要維護請求之間的狀態,可以使用 ASP.NET 頁面使用的相同技術(例如,Session 和 Application 屬性包),也可以自己實現自定義的解決方案。

  .NET Remoting 支持許多狀態管理選項,並且可能與來自同一個用戶的多個調用相關或不相關,這取決於您選擇的對象生命週期架構。SingleCall 對象是無狀態的(如用於調用 ASP.NET Web 服務的對象),Singleton 對象共享所有客戶端的狀態,客戶端激活的對象在每個客戶端的基礎上保持狀態(帶有其產生的所有相關的可升級性和可靠性問題)。

  性能

  從原始性能方面來講,使用 TCP 信道和二進制格式化程序時,.NET Remoting 管線能夠提供最快的通信。在我們進行的比較 ASP.NET Web 服務和 .NET Remoting 的相對性能的幾乎所有的測試中,ASP.NET Web 服務在性能上都超出了使用 HTTP 或 TCP 信道的 SOAP 格式化程序的 .NET Remoting 端點。更有意思的是,使用二進制格式化程序和 HTTP 信道的 ASP.NET 和 .NET Remoting 端點在性能上非常相近。(更多信息,請參見 Performance Comparison:NET Remoting vs. ASP.NET Web Services。)

  企業服務

  ASP.NET Web 服務或通過 .NET Remoting 提供的對象可以使用本地事務根據單個數據庫協調工作。如果需要根據多個資源協調工作,可以使用 .NET 企業服務(又稱 COM+)公佈的事務(由 COM+ 管線管理的 DTC 分佈式事務)。但要注意的是,ASP.NET Web 服務和 .NET Remoting 管線都不能傳播公佈的事務,因此兩種端點都不可能通過跨進程的調用繼承公佈的事務。

  這不一定是件壞事。一般來講,公佈的事務比本地事務代價要高,而要跨進程傳播公佈的事務,則代價會更高。如果確實需要這一功能,簡單的解決方案是在 .NET 企業服務的服務器應用程序中部署一個從 System.EnterpriseServices.ServicedComponent 派生的類(更多信息,請參見 COM+ Integration:How .NET Enterprise Services Can Help You Build Distributed Applications)。對該類對象的跨進程調用將使用 DCOM 進行處理,以確保正確傳播事務環境。較難的解決方案是使用底層的 API,手動傳播分佈的事務。

  值得注意的是,傳統的分佈式事務模型一般不適用於鬆散耦合的 Web 服務。基於補償事務的模型(即,撤消其他事務所提交工作的事務)更有意義,因爲其隔離約束條件並不是很嚴格。在包括 Microsoft 的 Web 服務供應商中有一種普遍的說法,即 Web 服務空間需要的事務模型越靈活,該空間中進行的工作越多。等到定義出 Web 服務事務的標準方法時,您就可以根據情況使用本地或公佈的事務實現自己的補償架構了。

  小結

  雖然 .NET Remoting 基礎結構和 ASP.NET Web 服務都可以進行跨進程通信,但每種設計適用於不同的用戶。ASP.NET Web 服務提供了簡單的編程模型,並具有廣泛的使用範圍。.NET Remoting 提供了較爲複雜的編程模型,而且使用範圍窄得多。請務必瞭解這兩種技術的工作原理,並選擇適合您應用程序的技術。在任意一種情況下,都要使用 IIS 和 ASP.NET 管理進程生命週期,並提供一般的安全性。

  我採用Remoting技術也是項目的需要:

  1、Remoteing主要用於C/S結構項目。

  2、將Remoting採用TCP通訊,比Web Service不是稍微高效一些,而是高几倍,甚至幾十倍,不愧爲是在DCOM等基礎上發展起來的技術。對於跨地區,乃至跨省(廣域網)的分佈式應用,效率的高低意味着軟件系統的生死存亡。

  我在博客上說的這個三層結構,本意也只是在.net環境下,利用反射技術、對象關係映射等技術,寫一個底層點的程序集,方便編寫數據庫訪問程序。該程序集要能封裝常用的數據庫操作。這個程序集不管是在Remoting、Web Service還是WCF,應該都能用的。就象我們在大學課本里學數據結構,學的是一種思想。如果只是單純侷限一種技術,在日新月異的發展中,終將淘汰。我們都是凡人,不可能掌握所有技術。適合自己項目需要的,就是最好的!

文章來源:http://yysyb123.blog.163.com/blog/static/192050472010120105736192/?fromdm&fromSearch

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章