WCF Streaming流处理相关特点以及应用技巧讲解
创始人
2024-06-23 09:31:04
0

WCF中有很多比较深奥的内容需要我们在不断的实践中去深入研究。比如今天为大家介绍的WCF Streaming流处理,就是其中一个比较难以理解的内容。希望本文介绍的内容能够给大家带来一些帮助。#t#

Streaming流处理的特点:

显然对于处理大量的消息数据而言,流处理机制改善了系统的吞吐量和响应效率。

WCF Streaming流处理操作定义:

WCF Streaming流处理机制需要使用.NET FrameWork定义的Stream类(它是FileStream, NetworkStream, MemoryStream 的父类)。流处理适用一下场景:

 

 

  1. [ServiceContract]  
  2. interface IMyContract  
  3. {  
  4. [OperationContract]  
  5. Stream StreamReply1( );  
  6. [OperationContract]  
  7. void StreamReply2(out Stream stream);  
  8. [OperationContract]  
  9. void StreamRequest(Stream stream);  
  10. [OperationContract(IsOneWay = true)]  
  11. void OneWayStream(Stream stream);  

 

它可以做为返回数据、参数、输出参数的类型。当然也可以作为单调服务的操作参数。这里使用的参数必须是可序列化的,例如MemoryStream。而FileStream不支持序列化因而不能作为参数或者返回数据的类型。

WCF Streaming流处理与绑定协议:

流处理机制在特定的绑定协议中才能使用,目前是BasicHttpBinding, NetTcpBinding, 和NetNamedPipeBinding 支持流处理模型。但是在默认情况下,WCF禁止流处理模式。

流传输模式使用使用TransferMode进行配置,TransferMode为枚举类型,其定义如下:

 

  1. public enum TransferMode  
  2. {  
  3. // Summary:  
  4. // The request and response messages are both buffered.  
  5. Buffered = 0,  
  6. //  
  7. // Summary:  
  8. // The request and response messages are both streamed.  
  9. Streamed = 1,  
  10. //  
  11. // Summary:  
  12. // The request message is streamed and the response message is buffered.  
  13. StreamedRequest = 2,  
  14. //  
  15. // Summary:  
  16. // The request message is buffered and the response message is streamed.  
  17. StreamedResponse = 3,  

只有Streamed模式支持2.1中列举的流处理模式场景。除了直接在服务上配置属性以外,我们还可以再服务的配置文件里定义流传输模式。代码如下:

 

 

  1. < basicHttpBinding> 
  2. < binding name="basicHttpBinding" receiveTimeout="10:10:10" 
    transferMode="Streamed" maxReceivedMessageSize="200000"> 
  3. < /binding> 
  4. < /basicHttpBinding> 
  5. < netTcpBinding> 
  6. < binding name="netTcpBinding" receiveTimeout="10:10:10" 
    transferMode="Streamed" maxReceivedMessageSize="200000"> 
  7. < /binding> 
  8. < /netTcpBinding> 

此为托管宿主的配置文件,特定的绑定协议,可以配置其传输模式。

注意:

WCF Streaming流处理在使用http协议时,其默认消息长度是64K,如果希望增加数据长度,需要在配置文件里重新设置。如: maxReceivedMessageSize="200000",具体代码如下:

 

 

 

  1. < basicHttpBinding> 
  2. < binding name="basicHttpBinding" receiveTimeout="10:10:10" 
    transferMode="Streamed" maxReceivedMessageSize="200000"> 
  3. < /binding> 
  4. < /basicHttpBinding> 

以上就是我们对WCF Streaming流处理的相关介绍。

相关内容

热门资讯

如何允许远程连接到MySQL数... [[277004]]【51CTO.com快译】默认情况下,MySQL服务器仅侦听来自localhos...
如何利用交换机和端口设置来管理... 在网络管理中,总是有些人让管理员头疼。下面我们就将介绍一下一个网管员利用交换机以及端口设置等来进行D...
施耐德电气数据中心整体解决方案... 近日,全球能效管理专家施耐德电气正式启动大型体验活动“能效中国行——2012卡车巡展”,作为该活动的...
Windows恶意软件20年“... 在Windows的早期年代,病毒游走于系统之间,偶尔删除文件(但被删除的文件几乎都是可恢复的),并弹...
20个非常棒的扁平设计免费资源 Apple设备的平面图标PSD免费平板UI 平板UI套件24平图标Freen平板UI套件PSD径向平...
德国电信门户网站可实时显示全球... 德国电信周三推出一个门户网站,直观地实时提供其安装在全球各地的传感器网络检测到的网络攻击状况。该网站...
着眼MAC地址,解救无法享受D... 在安装了DHCP服务器的局域网环境中,每一台工作站在上网之前,都要先从DHCP服务器那里享受到地址动...
为啥国人偏爱 Mybatis,... 关于 SQL 和 ORM 的争论,永远都不会终止,我也一直在思考这个问题。昨天又跟群里的小伙伴进行...