• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>

            牽著老婆滿(mǎn)街逛

            嚴(yán)以律己,寬以待人. 三思而后行.
            GMail/GTalk: yanglinbo#google.com;
            MSN/Email: tx7do#yahoo.com.cn;
            QQ: 3 0 3 3 9 6 9 2 0 .

            信道(Channel)、接收器(Sink)、接收鏈(Sink Chain)和信道接受提供程序(Channel Sink Provider)

            來(lái)源:http://www.cnblogs.com/rickie/archive/2004/10/16/52983.html


            Channel, Sink, Sink Chain and Channel Sink Provider

             

            為了擴(kuò)展.Net Remoting,定制接收器(Sink)和信道接受提供程序(Channel Sink Provider),改變.Net Remoting的缺省行為,需要先了解.Net Remoting的相關(guān)概念及其運(yùn)行機(jī)制。

             

            下面先了解一些基本概念:

             

            信道(Channel-是跨遠(yuǎn)程處理邊界(無(wú)論是在應(yīng)用程序域、進(jìn)程還是計(jì)算機(jī)之間)在應(yīng)用程序之間傳輸消息的對(duì)象。信道可以在終結(jié)點(diǎn)上偵聽(tīng)入站消息,向另一個(gè)終結(jié)點(diǎn)發(fā)送出站消息,或者兩者都可以。

            信道必須實(shí)現(xiàn) IChannel 接口,該接口提供諸如 ChannelName ChannelPriority 這樣的屬性。專(zhuān)用于在特定端口上偵聽(tīng)特定協(xié)議的信道實(shí)現(xiàn) IChannelReceiver,而專(zhuān)用于發(fā)送信息的信道實(shí)現(xiàn) IChannelSender(注:IChannelReceiverIChannelSender接口都繼承IChannel 接口)。TcpChannel HttpChannel 對(duì)象都實(shí)現(xiàn)這兩種接口,因此它們可用于發(fā)送或接收信息。

            .Net Remoting Framework提供了TcpChannel HttpChannel兩個(gè)信道的實(shí)現(xiàn)。

             

            在發(fā)送消息之前或接收消息之后,信道(Channel)沿著信道接收對(duì)象鏈(a chain of channel sink objects)發(fā)送每個(gè)消息。該接收鏈(sink chain)包含基本信道功能所需的接收器(Sink(如格式化程序接收器FormatterSink、傳輸接收器TransportSink或堆棧生成器接收器StackBuilderSink),但是您可以自定義信道接收鏈以便用消息或流執(zhí)行特殊任務(wù)。

             

            信道接收鏈(Sink Chain處理任何發(fā)送到應(yīng)用程序域或從應(yīng)用程序域發(fā)送的消息。此時(shí),您只有消息,但是您可以任意操作該消息,而后面的處理將使用您在處理之后返回給系統(tǒng)的消息。這是實(shí)現(xiàn)日志記錄服務(wù)、任何種類(lèi)的篩選器或者客戶(hù)端或服務(wù)器上的加密或其他安全措施的理所當(dāng)然的位置。以下插圖顯示基本信道接收鏈的結(jié)構(gòu)。



            每個(gè)信道接收器(Channel Sink都處理流,然后將流傳遞到下一個(gè)信道接收器,這意味著您的接收器之前或之后的對(duì)象應(yīng)當(dāng)知道該如何處理傳遞給它們的流。(Sink/Channel Sink是同一個(gè)描述。)

            StackBuilderSink 對(duì)象是服務(wù)器上遠(yuǎn)程對(duì)象前的最后一個(gè)消息接收器。

             

            每個(gè)信道接收器(Channel Sink)或者實(shí)現(xiàn) IClientChannelSink,或者實(shí)現(xiàn) IServerChannelSink。客戶(hù)端上的第一個(gè)信道接收器還必須實(shí)現(xiàn) IMessageSink。它通常實(shí)現(xiàn) IClientFormatterSink(它從 IMessageSinkIChannelSinkBase IClientChannelSink 繼承),并被稱(chēng)作格式化程序接收器(Formatter Sink),因?yàn)樗鼘魅氲南⑥D(zhuǎn)換為流(IMessage 對(duì)象)。

             

            信道接收提供程序(Channel Sink Provider-(實(shí)現(xiàn) IClientChannelSinkProviderIClientFormatterSinkProvider IServerChannelSinkProvider 接口的對(duì)象)負(fù)責(zé)創(chuàng)建遠(yuǎn)程處理消息所流過(guò)的信道接收器(Channel Sink)。當(dāng)遠(yuǎn)程類(lèi)型被激活后,將從信道(Channel)中檢索信道接收提供程序(Channel Sink Provider);然后在該接收提供程序上調(diào)用 CreateSink 方法以檢索鏈上的接收器中的第一個(gè)Sink

             

            信道接收器(Channel Sink)還負(fù)責(zé)在客戶(hù)端和服務(wù)器之間傳輸消息。信道接收器也鏈接在一起而形成一個(gè)鏈。當(dāng)在接收提供程序上調(diào)用 CreateSink 方法時(shí),該方法應(yīng)該執(zhí)行以下操作:

            ·         創(chuàng)建它自己的信道接收器。

            ·         在鏈中的下一個(gè)接收提供程序上調(diào)用 CreateSink

            ·         確保下一個(gè)接收器和當(dāng)前的接收器鏈接在一起。

            ·         將其接收器返回到調(diào)用方。

            信道接收器負(fù)責(zé)將在它們上面進(jìn)行的所有調(diào)用轉(zhuǎn)發(fā)到鏈中的下一個(gè)接收器,并且應(yīng)當(dāng)提供用于存儲(chǔ)對(duì)下一個(gè)接收器的引用的機(jī)制。

             

            自定義信道接收器(Custom Channel Sinks

            自定義信道接收器被插入到格式化程序接收器(FormatterSink)和最后一個(gè)傳輸接收器(TransportSink)之間的對(duì)象鏈中。

             

            傳輸接收器(TransportSink

            傳輸接收器是客戶(hù)端上的鏈中最后一個(gè)接收器和服務(wù)器端上的鏈中第一個(gè)接收器。除了傳輸序列化的消息,傳輸接收器還負(fù)責(zé)將標(biāo)頭(Header)發(fā)送到服務(wù)器并在調(diào)用從服務(wù)器返回時(shí)檢索標(biāo)頭和流。這些接收器內(nèi)置在信道中,并且無(wú)法擴(kuò)展。

             

            簡(jiǎn)要總結(jié).Net Remoting Infrastructure機(jī)制:

            1,代理對(duì)象(Proxy)負(fù)責(zé)轉(zhuǎn)發(fā)對(duì)Remote Objects的調(diào)用。

            2,消息對(duì)象(Message Objects)用來(lái)調(diào)用Remote Methods的數(shù)據(jù)。

            3,信道接收器(Sink/Channel Sink)用來(lái)遠(yuǎn)程方法調(diào)用(Remote method calls)處理消息。

            4,信道接收提供程序(Channel Sink Provider)-一般用來(lái)將接收器(Sink)插入到信道接收鏈(Sink Chain)中。

            5,格式化程序接收器FormatterSink-用來(lái)序列化/反序列化消息格式,進(jìn)行傳遞。

            6,傳輸接收器TransportSink-用來(lái)在進(jìn)程或AppDomain之間傳遞序列化的消息。

             

            Reference:

            1, MSDN, .NET Framework 開(kāi)發(fā)員指南, 接收器和接收鏈

            posted on 2009-02-04 01:47 楊粼波 閱讀(876) 評(píng)論(0)  編輯 收藏 引用


            只有注冊(cè)用戶(hù)登錄后才能發(fā)表評(píng)論。
            網(wǎng)站導(dǎo)航: 博客園   IT新聞   BlogJava   博問(wèn)   Chat2DB   管理


            国产精品久久久久久福利漫画 | 伊人久久大香线焦AV综合影院| 一本色综合久久| 97久久婷婷五月综合色d啪蜜芽| 欧美丰满熟妇BBB久久久| 日本久久久久久中文字幕| 久久久久久毛片免费看| 无码精品久久久天天影视| 国产精品视频久久久| 久久成人小视频| 91久久精品国产成人久久| 伊人久久大香线蕉综合Av| 伊人久久大香线蕉影院95| 久久国语露脸国产精品电影| 一本大道加勒比久久综合| 2021国内精品久久久久久影院| 成人国内精品久久久久影院| 久久久久亚洲AV无码专区首JN| 99久久综合狠狠综合久久| 亚洲精品高清国产一线久久 | 亚洲精品tv久久久久| 国产国产成人精品久久| 囯产极品美女高潮无套久久久| 精品久久久久久无码人妻热| 久久综合给合久久狠狠狠97色69| 久久综合一区二区无码| Xx性欧美肥妇精品久久久久久| 久久精品人人槡人妻人人玩AV| 一本色道久久88综合日韩精品| 国产三级观看久久| 国产精品免费久久久久久久久| 99久久国产热无码精品免费| 久久久久久国产精品无码超碰| 久久中文字幕人妻熟av女| 伊人久久无码精品中文字幕| 久久男人AV资源网站| 国产巨作麻豆欧美亚洲综合久久| 久久99国产精品一区二区| 国产午夜精品理论片久久影视 | 久久黄视频| 久久影院午夜理论片无码|