Channel, Sink, Sink Chain and Channel Sink Provider
為了擴展 .Net Remoting ,定制接收器( Sink )和信道接受提供程序( Channel Sink Provider ),改變 .Net Remoting 的缺省行為,需要先了解 .Net Remoting 的相關概念及其運行機制。
下面先了解一些基本概念:
信道( Channel ) -是跨遠程處理邊界(無論是在應用程序域、進程還是計算機之間)在應用程序之間傳輸消息的對象。信道可以在終結點上偵聽入站消息,向另一個終結點發送出站消息,或者兩者都可以。
信道必須實現 IChannel 接口,該接口提供諸如 ChannelName 和 ChannelPriority 這樣的屬性。專用于在特定端口上偵聽特定協議的信道實現 IChannelReceiver ,而專用于發送信息的信道實現 IChannelSender (注: IChannelReceiver 和 IChannelSender 接口都繼承 IChannel 接口)。 TcpChannel 和 HttpChannel 對象都實現這兩種接口,因此它們可用于發送或接收信息。
.Net Remoting Framework 提供了 TcpChannel 和 HttpChannel 兩個信道的實現。
在發送消息之前或接收消息之后,信道( Channel )沿著信道接收對象鏈( a chain of channel sink objects )發送每個消息。該接收鏈( sink chain )包含基本信道功能所需的 接收器( Sink ) (如格式化程序接收器 FormatterSink 、傳輸接收器 TransportSink 或堆棧生成器接收器 StackBuilderSink ),但是您可以自定義信道接收鏈以便用消息或流執行特殊任務。
信道接收鏈(
Sink Chain
)
處理任何發送到應用程序域或從應用程序域發送的消息。此時,您只有消息,但是您可以任意操作該消息,而后面的處理將使用您在處理之后返回給系統的消息。這是實現日志記錄服務、任何種類的篩選器或者客戶端或服務器上的加密或其他安全措施的理所當然的位置。以下插圖顯示基本信道接收鏈的結構。
每個 信道接收器( Channel Sink ) 都處理流,然后將流傳遞到下一個信道接收器,這意味著您的接收器之前或之后的對象應當知道該如何處理傳遞給它們的流。( Sink/Channel Sink 是同一個描述。)
StackBuilderSink 對象是服務器上遠程對象前的最后一個消息接收器。
每個信道接收器( Channel Sink )或者實現 IClientChannelSink ,或者實現 IServerChannelSink ??蛻舳松系牡谝粋€信道接收器還必須實現 IMessageSink 。它通常實現 IClientFormatterSink (它從 IMessageSink 、 IChannelSinkBase 和 IClientChannelSink 繼承),并被稱作格式化程序接收器( Formatter Sink ),因為它將傳入的消息轉換為流( IMessage 對象)。
信道接收提供程序( Channel Sink Provider ) -(實現 IClientChannelSinkProvider 、 IClientFormatterSinkProvider 或 IServerChannelSinkProvider 接口的對象)負責創建遠程處理消息所流過的信道接收器( Channel Sink )。當遠程類型被激活后,將從信道( Channel )中檢索信道接收提供程序( Channel Sink Provider );然后在該接收提供程序上調用 CreateSink 方法以檢索鏈上的接收器中的第一個 Sink 。
信道接收器( Channel Sink )還負責在客戶端和服務器之間傳輸消息。信道接收器也鏈接在一起而形成一個鏈。當在接收提供程序上調用 CreateSink 方法時,該方法應該執行以下操作:
· 創建它自己的信道接收器。
· 在鏈中的下一個接收提供程序上調用 CreateSink 。
· 確保下一個接收器和當前的接收器鏈接在一起。
· 將其接收器返回到調用方。
信道接收器負責將在它們上面進行的所有調用轉發到鏈中的下一個接收器,并且應當提供用于存儲對下一個接收器的引用的機制。
自定義信道接收器( Custom Channel Sinks )
自定義信道接收器被插入到格式化程序接收器( FormatterSink )和最后一個傳輸接收器( TransportSink )之間的對象鏈中。
傳輸接收器( TransportSink )
傳輸接收器是客戶端上的鏈中最后一個接收器和服務器端上的鏈中第一個接收器。除了傳輸序列化的消息,傳輸接收器還負責將標頭( Header )發送到服務器并在調用從服務器返回時檢索標頭和流。這些接收器內置在信道中,并且無法擴展。
簡要總結 .Net Remoting Infrastructure 機制:
1 ,代理對象( Proxy )負責轉發對 Remote Objects 的調用。
2 ,消息對象( Message Objects )用來調用 Remote Methods 的數據。
3 ,信道接收器( Sink/Channel Sink )用來遠程方法調用( Remote method calls )處理消息。
4 ,信道接收提供程序( Channel Sink Provider )-一般用來將接收器( Sink )插入到信道接收鏈( Sink Chain )中。
5 ,格式化程序接收器 FormatterSink -用來序列化 / 反序列化消息格式,進行傳遞。
6 ,傳輸接收器 TransportSink -用來在進程或 AppDomain 之間傳遞序列化的消息。
Reference:
1, MSDN, .NET Framework 開發員指南 , 接收器和接收鏈
更多文章、技術交流、商務合作、聯系博主
微信掃碼或搜索:z360901061

微信掃一掃加我為好友
QQ號聯系: 360901061
您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點擊下面給點支持吧,站長非常感激您!手機微信長按不能支付解決辦法:請將微信支付二維碼保存到相冊,切換到微信,然后點擊微信右上角掃一掃功能,選擇支付二維碼完成支付。
【本文對您有幫助就好】元
