chinese直男口爆体育生外卖, 99久久er热在这里只有精品99, 又色又爽又黄18禁美女裸身无遮挡, gogogo高清免费观看日本电视,私密按摩师高清版在线,人妻视频毛茸茸,91论坛 兴趣闲谈,欧美 亚洲 精品 8区,国产精品久久久久精品免费

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

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

3天內(nèi)不再提示

WCF技術(shù)的實例模式的實現(xiàn)原理剖析

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

掃碼添加小助手

加入工程師交流群

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

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

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

一、實例上下文(InstanceContext)

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

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

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

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

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

圖1 實例上下文對服務(wù)實例的封裝

實例上下文通過類型System.ServiceModel.InstanceContext表示。InstanceContext繼承自CommunicationObject,實現(xiàn)了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具有三個構(gòu)造函數(shù),接受ServiceHostBase對象和具體的實例對象作為其輸入?yún)?shù)。GetServiceInstance和ReleaseServiceInstance用戶服務(wù)實例的獲取和釋放。IncomingChannels和OutgoingChannels則表示入棧和出棧信道集合。而通過SynchronizationContext屬性則可以設(shè)置或獲取用于異步操作的同步上下文,比如服務(wù)操作須要在非UI線程下操作一個Windows Form的控件,你就需要基于UI線程的同步上下文(SynchronizationContext)。

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

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

1、單調(diào)(Per-Call)模式

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

圖2 單調(diào)模式下服務(wù)代理與服務(wù)實例上下文之間的關(guān)聯(lián)

2、會話(Per-Session)模式

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

圖3 會話模式下服務(wù)代理與服務(wù)實例上下文之間的關(guān)聯(lián)

3、單例(Single)模式

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

圖4 會話模式下服務(wù)代理與服務(wù)實例上下文之間的關(guān)聯(lián)

三、 實例服務(wù)行為

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

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

   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: }

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

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

    關(guān)注

    31

    文章

    5434

    瀏覽量

    124550
  • WCF
    WCF
    +關(guān)注

    關(guān)注

    0

    文章

    4

    瀏覽量

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

掃碼添加小助手

加入工程師交流群

    評論

    相關(guān)推薦
    熱點推薦

    實例解讀模擬電子技術(shù)

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

    UIAbility組件啟動模式實例在啟動時的不同呈現(xiàn)狀態(tài)

    UIAbility組件啟動模式 UIAbility的啟動模式是指UIAbility實例在啟動時的不同呈現(xiàn)狀態(tài)。針對不同的業(yè)務(wù)場景,系統(tǒng)提供了三種啟動模式: singleton(單
    發(fā)表于 05-16 06:10

    智能關(guān)停,高速風筒方案中陀螺儀技術(shù)的精準應(yīng)用

    今天給大家深入剖析一款基于陀螺儀技術(shù)實現(xiàn)智能關(guān)停的高速風筒方案,看看它是如何在細節(jié)之處展現(xiàn)科技的魅力。
    的頭像 發(fā)表于 04-17 19:01 ?811次閱讀
    智能關(guān)停,高速風筒方案中陀螺儀<b class='flag-5'>技術(shù)</b>的精準應(yīng)用

    電機故障診斷常見誤區(qū)的剖析

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

    直流電源CV/CC模式實現(xiàn)原理

    直流電源實現(xiàn)恒壓(CV)和恒流(CC)模式輸出的核心在于 雙閉環(huán)反饋控制 ,通過電壓和電流的實時監(jiān)測與動態(tài)調(diào)整,確保在負載變化時自動切換模式。以下是具體實現(xiàn)原理和步驟: 1、基本工作原
    的頭像 發(fā)表于 03-19 15:34 ?2289次閱讀

    深入剖析智芯傳感開口封封裝技術(shù)

    封裝是MEMS制造過程的重要環(huán)節(jié),決定了MEMS器件的可靠性和成本。開口封封裝技術(shù)是智芯傳感在封裝工藝上的一次創(chuàng)新突破。這一創(chuàng)新技術(shù)不僅攻克了MEMS壓力傳感芯片一體化塑封的這一世界級難題,還憑借其卓越的性能與高效生產(chǎn)優(yōu)勢,引領(lǐng)著行業(yè)的
    的頭像 發(fā)表于 03-19 10:39 ?626次閱讀
    深入<b class='flag-5'>剖析</b>智芯傳感開口封封裝<b class='flag-5'>技術(shù)</b>

    全面剖析倒裝芯片封裝技術(shù)的內(nèi)在機制、特性優(yōu)勢、面臨的挑戰(zhàn)及未來走向

    半導體技術(shù)的日新月異,正引領(lǐng)著集成電路封裝工藝的不斷革新與進步。其中,倒裝芯片(Flip Chip)封裝技術(shù)作為一種前沿的封裝工藝,正逐漸占據(jù)半導體行業(yè)的核心地位。本文旨在全面剖析倒裝芯片封裝
    的頭像 發(fā)表于 03-14 10:50 ?774次閱讀

    隔離型DCDC偏置電源供應(yīng)技術(shù)深度剖析

    型DC/DC偏置電源供應(yīng)的技術(shù)特點、拓撲結(jié)構(gòu)、新一代解決方案及選擇策略,為相關(guān)領(lǐng)域的設(shè)計師提供參考。 *附件:隔離型DCDC偏置電源供應(yīng)技術(shù)深度剖析.pdf 2. 隔離型DC/DC偏置電源供應(yīng)概述 隔離型DC/DC偏置電源供應(yīng)是
    的頭像 發(fā)表于 02-14 11:05 ?1283次閱讀
    隔離型DCDC偏置電源供應(yīng)<b class='flag-5'>技術(shù)</b>深度<b class='flag-5'>剖析</b>

    BNC接頭技術(shù)原理與工程應(yīng)用剖析:從結(jié)構(gòu)到性能優(yōu)化

    在現(xiàn)代電子通信和射頻領(lǐng)域,BNC接頭作為一種廣泛應(yīng)用的連接器件,發(fā)揮著至關(guān)重要的作用。它以其可靠的連接性能、優(yōu)異的電氣特性和廣泛的兼容性,成為眾多電子設(shè)備和系統(tǒng)中不可或缺的一部分。本文將深入剖析
    的頭像 發(fā)表于 12-31 16:07 ?1509次閱讀
    BNC接頭<b class='flag-5'>技術(shù)</b>原理與工程應(yīng)用<b class='flag-5'>剖析</b>:從結(jié)構(gòu)到性能優(yōu)化

    如何實現(xiàn)EEPROM的低功耗模式

    內(nèi)容進行擦除和重寫。在許多應(yīng)用中,尤其是在電池供電的設(shè)備中,低功耗模式對于延長設(shè)備的使用壽命至關(guān)重要。以下是實現(xiàn)EEPROM低功耗模式的一些方法: 1. 選擇合適的EEPROM類型 選擇功耗較低
    的頭像 發(fā)表于 12-16 16:54 ?1013次閱讀

    明達技術(shù)為您剖析軟&amp;硬協(xié)議棧

    在當今這個科技日新月異的時代,每一個細微之處都蘊含著無限可能。今天,讓我們一同深入探索網(wǎng)絡(luò)協(xié)議棧領(lǐng)域的兩大核心實現(xiàn)方式——軟協(xié)議棧與硬協(xié)議棧,它們各具特色,適用于多樣化的應(yīng)用場景。本文將為您剖析這兩種協(xié)議棧的異同,以及它們各自擅長的領(lǐng)域。
    的頭像 發(fā)表于 11-23 16:28 ?467次閱讀
    明達<b class='flag-5'>技術(shù)</b>為您<b class='flag-5'>剖析</b>軟&amp;硬協(xié)議棧

    如何實現(xiàn)智慧交通的多模式銜接

    實現(xiàn)智慧交通的多模式銜接是一個復(fù)雜而系統(tǒng)的工程,它涉及多種交通方式的整合、信息共享、技術(shù)應(yīng)用等多個方面。以下是一些關(guān)鍵步驟和策略,以實現(xiàn)智慧交通的多
    的頭像 發(fā)表于 11-22 18:11 ?1912次閱讀

    深入剖析2.5D封裝技術(shù)優(yōu)勢及應(yīng)用

    的一項重要創(chuàng)新,不僅提高了芯片的性能和集成度,還為未來的芯片設(shè)計提供了更多的可能性。本文將深入剖析2.5D封裝技術(shù)的內(nèi)涵、優(yōu)勢及其在現(xiàn)代半導體工業(yè)中的應(yīng)用。 一、芯片封裝的重要性 封裝作為半導體制造流程中的關(guān)鍵環(huán)節(jié),其核心作用在
    的頭像 發(fā)表于 11-22 09:12 ?3211次閱讀
    深入<b class='flag-5'>剖析</b>2.5D封裝<b class='flag-5'>技術(shù)</b>優(yōu)勢及應(yīng)用

    使用TPS22915B負載開關(guān)實現(xiàn)Ship模式

    電子發(fā)燒友網(wǎng)站提供《使用TPS22915B負載開關(guān)實現(xiàn)Ship模式.pdf》資料免費下載
    發(fā)表于 09-30 09:52 ?0次下載
    使用TPS22915B負載開關(guān)<b class='flag-5'>實現(xiàn)</b>Ship<b class='flag-5'>模式</b>

    CC2340系統(tǒng)降低成本的方案剖析

    電子發(fā)燒友網(wǎng)站提供《CC2340系統(tǒng)降低成本的方案剖析.pdf》資料免費下載
    發(fā)表于 08-27 09:43 ?0次下載
    CC2340系統(tǒng)降低成本的方案<b class='flag-5'>剖析</b>