国产精品久久久aaaa,日日干夜夜操天天插,亚洲乱熟女香蕉一区二区三区少妇,99精品国产高清一区二区三区,国产成人精品一区二区色戒,久久久国产精品成人免费,亚洲精品毛片久久久久,99久久婷婷国产综合精品电影,国产一区二区三区任你鲁

0
  • 聊天消息
  • 系統消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發帖/加入社區
會員中心
創作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內不再提示

WCF技術的實例模式的實現原理剖析

454398 ? 來源:博客園 ? 作者:蔣金楠 ? 2020-11-03 11:10 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

服務調用的目的體現在對某項服務功能的消費上,而功能的實現又定義在相應的服務類型中。不論WCF服務端框架處理服務調用請求的流程有多么復雜,最終都落實在服務實例的激活和操作方法的執行上面。WCF中的實例管理(Instance Management)旨在解決服務實例的激活和服務實例生命周期的控制。

會話(Session)的目的在于保持來自相同客戶端(服務代理)多次服務調用之間的狀態。從消息交換的角度來講,會話通過消息識別機制判斷調用某個服務的消息來源,從而將來自相同客戶端的所有消息關聯在一起。所以,會話實現了消息關聯(Message Correlation)。

實例與會話是WCF非常重要的兩個特性,它們既相對獨立,又互相制約。實例模式與對會話支持程度的不同組合,會讓最終的服務表現出截然不同的行為。對實例管理和會話的合理利用,對于改善和提高WCF服務應用的可擴展性(Scalability)、性能(Performance)、吞吐量(Throughput)等具有決定性作用。服務實例對象并不是孤立存在的,而是被封裝到一個特殊實例上下文(InstanceContext)對象之中,本系列文章從實例上下文說起。

一、實例上下文(InstanceContext)

實例上下文是對服務實例的封裝,是WCF管理服務實例生命周期的依托。我們先撇開WCF,來簡單介紹一下在托管的環境中,公共語言運行時(CLR)是如何進行托管對象的生命周期的。在一個托管應用程序中,我們通過不同的方式創建一個托管對象(比如通過new關鍵字、反射或反序列化等)時,CLR會在托管堆為該對象開辟一塊內存空間。對象的本質就是存儲于某塊內存中數據的體現,對象的生命周期終止于相應內存被回收之時。對于CLR來說,負責對托管堆(在這里主要指GC堆)進行回收的組件是垃圾收集器(GC),GC掌握著托管對象的生殺大權,決定著托管對象的生命周期。

當GC在進行垃圾回收的時候,會將“無用”的對象標記為垃圾對象,然后再對垃圾對象進行清理。GC對“無用”對象的識別機制很簡單:判斷對象是否被“根(Root)”所引用。在這里,“根”是對一組當前正被使用,或者以后可能被使用的對象的統稱,大體包括這樣的對象:類型的靜態字段或當前的方法參數和局部變量、CPU寄存器等。

所以,孤立存在的對象將難逃被GC回收的厄運。反之,如果希望某個對象常駐內存中,我們唯一的方式就是通過某個“根”引用該對象。本章所講的實例管理,就是對服務實例生命周期的管理,即讓服務實例按照我們希望的方式創建、存活和消亡,所以我們唯一的方式也只能是:在希望服務實例存活的時候讓它被某個“根”引用,從而阻止GC將其回收;在希望服務實例被回收的時候連“根”去除,使GC能夠將其回收。而本節所講的實例上下文(InstanceContext)就扮演著“根”的角色。

說到實例上下文,相信讀者不會感到陌生,因為在進行WCF雙向(Duplex)通信的時候,我們通過實例上下文來封裝回調對象。在WCF中,實例上下文不僅僅用于對回調對象的封裝,也用于對真正服務實例的封裝。實際上可以將WCF的雙向通信理解成一種對等通信,通信的雙方是對等的參與者,并沒有嚴格的服務端和客戶端之分,或者說通信的雙方交替地扮演著服務與客戶的角色。客戶端正常調用服務端操作是一種服務調用;服務端回調客戶端操作也可以看成是一種服務調用。因此,通過實例上下文對回調對象和服務實例進行封裝本質上是一致的。

實例上下文對服務實例的封裝大體可以通過圖1表示。一個WCF服務通過一個ServiceHost進行寄宿,并添加一到多個終結點。對于接收到的服務調用請求,如果相應的實例上下文存在,則通過它得到服務實例來處理服務請求,否則創建服務實例并通過實例上下文對其進行封裝,然后再通過實例上下文得到具體的服務實例進行服務請求處理。

圖1 實例上下文對服務實例的封裝

實例上下文通過類型System.ServiceModel.InstanceContext表示。InstanceContext繼承自CommunicationObject,實現了IExtensibleObject接口。InstanceContext的定義如下面的代碼所示:

   1: public sealed class InstanceContext : CommunicationObject, IExtensibleObject
   2: {   
   3:     //其他成員
   4:     public InstanceContext(object implementation);
   5:     public InstanceContext(ServiceHostBase host);
   6:     public InstanceContext(ServiceHostBase host, object implementation);
   7: 
   8:     public object GetServiceInstance();
   9:     public object GetServiceInstance(Message message);
  10:     public void ReleaseServiceInstance();
  11: 
  12:     public IExtensionCollection Extensions { get; }
  13:     public ServiceHostBase Host { get; }
  14:     public ICollection IncomingChannels { get; }
  15:     public ICollection OutgoingChannels { get; }
  16:     public SynchronizationContext SynchronizationContext { get; set; }
  17: }

InstanceContext具有三個構造函數,接受ServiceHostBase對象和具體的實例對象作為其輸入參數。GetServiceInstance和ReleaseServiceInstance用戶服務實例的獲取和釋放。IncomingChannels和OutgoingChannels則表示入棧和出棧信道集合。而通過SynchronizationContext屬性則可以設置或獲取用于異步操作的同步上下文,比如服務操作須要在非UI線程下操作一個Windows Form的控件,你就需要基于UI線程的同步上下文(SynchronizationContext)。

二、實例上下文模式(InstanceContext Mode)

實例上下文模式(IntanceContext Mode)表示服務端的服務實例與客戶端的服務代理的綁定方式。如果讀者熟悉.NET Remoting,肯定會很清楚.NET Remoting具有兩種不同的遠程對象激活方式:服務端激活對象(SAO:Server Activated Object)和客戶端激活對象(CAO:Client Activated Object),而前者又具有兩種不同的變體:單調(SingleCall)和單例(Singleton)。單調模式意味著服務端對于接收到的調用,都會創建新的遠程對象,而單例模式則表示服務端使用相同的遠程對象處理來自不同客戶端的所有遠程調用。單調和單例模式體現了兩種極端的遠程對象激活方式,而CAO則是一種相對折中的方式:一個客戶端代理對象與一個遠程對象一一匹配。WCF實例上下文模式與.NET Remoting的遠程對象激活方式類似,同樣具有三種不同的實例上下文模式,分別與上述三種激活方式匹配。這三種實例上下文模式分別是:單調(Per-Call)模式、會話(Per-Session)模式和單例(Single)模式。

1、單調(Per-Call)模式

單調模式相當于.NET Remoting的SingleCall遠程對象激活方式。如果采用單調實例上下文模式,對于每一個服務調用,不論是來自相同的客戶端(服務代理)還是不同的客戶端,WCF總是創建一個全新的服務實例和實例上下文對象來處理服務調用請求。在服務操作執行完畢,實例上下文對象和被封裝的服務實例被回收調。圖2揭示了在單調模式下實例上下文、服務實例和服務代理之間的關聯。

圖2 單調模式下服務代理與服務實例上下文之間的關聯

2、會話(Per-Session)模式

會話(Session)的目的在于保持來自相同客戶端(即同一個服務代理)多次服務調用之間的狀態。如果從消息交互的角度來講,通過會話可以將來自相同客戶端的多個消息關聯在一起。在會話實例上下文模式下,WCF為每一個服務代理對象分配一個單獨的服務實例上下文對象,對于來自相同服務代理的所有服務調用請求,都將分發給相同的服務實例上下文處理。會話模式與.NET Remoting下的CAO遠程對象激活模式類似,圖3揭示了會話模式下實例上下文、服務實例和服務代理之間的關系。

圖3 會話模式下服務代理與服務實例上下文之間的關聯

3、單例(Single)模式

單例模式意味著WCF為每個服務維護一個并且僅維護一個服務實例上下文。不論請求來自相同的服務代理還是不同的服務代理,處理服務調用請求都是同一個服務實例上下文對象。單例模式相當于.NET Remoting下的Singleton遠程對象激活方式,圖4揭示了單例模式下實例上下文、服務實例和服務代理之間的關系。

圖4 會話模式下服務代理與服務實例上下文之間的關聯

三、 實例服務行為

在介紹服務寄宿的時候,我們談到過WCF下“契約(Contract)”和“行為(Behavior)”的區別:契約是涉及雙邊的描述(契約是服務的提供者和服務消費者進行交互的手段),那么行為就是基于單邊的描述。客戶端行為體現的是WCF如何進行服務調用的方式,而服務端行為則體現了WCF的請求分發方式。所以服務契約會通過元數據對外發布,而服務行為則對于客戶端是透明的。

對于客戶端來講,它所關心的是通過服務調用能夠獲得正確的結果,而不會關心服務端采用怎樣的模式來激活服務實例。所以,WCF實例管理通過服務行為體現,不同的實例上下文模式通過ServiceBehaviorAttribute特性指定。在ServiceBehaviorAttribute中,通過設置InstanceContextMode屬性來指定不同的服務實例上下文模式。

   1: [AttributeUsage(AttributeTargets.Class)]
   2: public sealed class ServiceBehaviorAttribute : Attribute, IServiceBehavior
   3: { 
   4:     //其他成員
   5:     public InstanceContextMode InstanceContextMode { get; set; }
   6: }

屬性InstanceContextMode的類型為System.ServiceModel.InstanceContextMode枚舉,三個枚舉值PerCall、PerSession和Single分別表示上述的三種實例上下文模式。默認選項為PerSession。

   1: public enum InstanceContextMode
   2: {
   3:     PerCall,
   4:     PerSession,
   5:     Single
   6: }

在本系列后續部分,我將對每一種實例模式的實現原理進行逐個剖析,相信極大的加深讀者對WCF下的服務對象生命周期管理機制的理解。
編輯:hfy

聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規問題,請聯系本站處理。 舉報投訴
  • 寄存器
    +關注

    關注

    31

    文章

    5608

    瀏覽量

    129968
  • WCF
    WCF
    +關注

    關注

    0

    文章

    4

    瀏覽量

    7109
收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評論

    相關推薦
    熱點推薦

    LMK04828 - EP:超低噪聲時鐘抖動清理器的技術剖析與應用指南

    LMK04828 - EP:超低噪聲時鐘抖動清理器的技術剖析與應用指南 在電子設計領域,時鐘信號的穩定性和低抖動特性對于系統的性能至關重要。LMK04828 - EP作為一款超低噪聲、符合
    的頭像 發表于 02-08 11:45 ?444次閱讀

    深入剖析MAX16812:集成高壓LED驅動的技術先鋒

    深入剖析MAX16812:集成高壓LED驅動的技術先鋒 在當今的電子世界中,LED照明技術的發展日新月異,而與之配套的LED驅動芯片也在不斷創新。MAX16812作為一款集成高壓LED驅動芯片,憑借
    的頭像 發表于 02-02 16:25 ?167次閱讀

    MCP2510:獨立CAN控制器的技術剖析與應用指南

    MCP2510:獨立CAN控制器的技術剖析與應用指南 在電子工程師的設計工具箱中,CAN(Controller Area Network)控制器是實現可靠通信的關鍵組件。Microchip
    的頭像 發表于 01-28 16:15 ?170次閱讀

    深度剖析L6566B:多模式SMPS控制器的卓越之選

    深度剖析L6566B:多模式SMPS控制器的卓越之選 在電源管理領域,一款優秀的控制器對于開關電源(SMPS)的性能起著決定性作用。今天,我們將深入探討STMicroelectronics推出
    的頭像 發表于 01-27 10:55 ?288次閱讀

    深入解析L6562:高性能過渡模式PFC控制器

    ,工作在過渡模式(TM),與前代L6561引腳兼容且性能更優。接下來,我們將詳細剖析L6562的特性、功能、應用及相關設計要點。 文件下載: l6562.pdf 特性亮點 先進工藝與模式 BCD
    的頭像 發表于 01-27 10:55 ?322次閱讀

    L6564T:高性能過渡模式PFC控制器的深度剖析

    L6564T:高性能過渡模式PFC控制器的深度剖析 在開關電源(SMPS)設計領域,功率因數校正(PFC)技術至關重要,它能夠提高電源效率、減少諧波污染。今天,我們要深入探討一款優秀的PFC控制器
    的頭像 發表于 01-27 10:35 ?783次閱讀

    深入剖析L6563/L6563A:高級過渡模式PFC控制器的卓越性能

    深入剖析L6563/L6563A:高級過渡模式PFC控制器的卓越性能 在開關電源(SMPS)設計中,功率因數校正(PFC)技術起著至關重要的作用,它能提高電源效率,降低諧波污染。L6563
    的頭像 發表于 01-27 10:30 ?320次閱讀

    剖析AD8451:電池測試與成型系統的高精度模擬前端控制器

    和豐富的功能。今天,我們就來深入剖析AD8451,探討它在電池測試與成型系統中的應用。 文件下載: AD8451.pdf 一、AD8451關鍵特性 (一)集成模式與自動切換 AD8451集成了恒流(CC)和恒壓(CV)模式,并能
    的頭像 發表于 01-14 11:15 ?210次閱讀

    AMD UltraScale架構:高性能FPGA與SoC的技術剖析

    AMD UltraScale架構:高性能FPGA與SoC的技術剖析 在當今的電子設計領域,高性能FPGA和MPSoC/RFSoC的需求日益增長。AMD的UltraScale架構憑借其創新的技術和卓越
    的頭像 發表于 12-15 14:35 ?555次閱讀

    ProfiNet嵌入式板卡,主流替代可實現ProfiNet工業以太網的應用實例

    ProfiNet嵌入式板卡,主流替代可實現ProfiNet工業以太網的應用實例
    的頭像 發表于 12-01 17:11 ?1113次閱讀
    ProfiNet嵌入式板卡,主流替代可<b class='flag-5'>實現</b>ProfiNet工業以太網的應用<b class='flag-5'>實例</b>

    Modbus協議的深度剖析

    Modbus協議作為工業自動化領域最廣泛應用的通信協議之一,其簡潔高效的特性使其在工業控制系統中占據重要地位。本文將從協議的發展歷程、技術架構、通信模式、安全機制以及未來演進等多個維度進行全面剖析
    的頭像 發表于 11-07 07:43 ?858次閱讀
    Modbus協議的深度<b class='flag-5'>剖析</b>

    【「DeepSeek 核心技術揭秘」閱讀體驗】--全書概覽

    講解Deepseek的使用方法 第三章 深入剖析Deepseek-V3的模型架構、訓練框架、推理階段優化、后訓練優化等關鍵技術 第四章關于DeepSeek-R1的技術剖析 第五章 從
    發表于 07-21 00:04

    實例解讀模擬電子技術

    資料介紹:本文通過豐富多彩的應用實例,由淺入深地剖析模擬電子電路各方面的知識。例如,通過電子地動儀的介紹帶領讀者進入電子學的殿堂,通過USB充電器和電池保護器介紹有關直流電源的知識,通過電子聽診器
    發表于 05-16 13:29

    UIAbility組件啟動模式實例在啟動時的不同呈現狀態

    UIAbility組件啟動模式 UIAbility的啟動模式是指UIAbility實例在啟動時的不同呈現狀態。針對不同的業務場景,系統提供了三種啟動模式: singleton(單
    發表于 05-16 06:10

    電機故障診斷常見誤區的剖析

    純分享帖,需要者可點擊附件獲取完整資料~~~*附件:電機故障診斷常見誤區的剖析.pdf (免責聲明:本文系網絡轉載,版權歸原作者所有。本文所用視頻、圖片、文字如涉及作品版權問題,請第一時間告知,刪除內容!)
    發表于 04-07 17:35