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 開發員指南, 接收器和接收鏈