WCF Streaming流处理相关特点以及应用技巧讲解

开发 开发工具
我们在这篇文章中主要针对WCF Streaming流处理的特点以及具体的操作定义做了一个详细的介绍,希望可以给大家带来一些帮助。

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流处理的相关介绍。

责任编辑:曹凯 来源: 博客园
相关推荐

2010-02-22 16:19:25

WCF自托管

2009-12-21 14:49:27

2010-02-23 14:17:20

WCF配置文件

2010-02-26 13:40:28

WCF消息头

2009-12-30 18:18:32

Silverlight

2009-12-21 18:10:50

WCF实现事件通知

2010-02-23 09:44:12

WCF dataCon

2010-03-02 10:54:42

WCF回调操作

2010-02-22 13:35:03

WCF异常处理

2010-02-23 09:34:15

WCF重载

2009-12-22 19:14:36

WCF效率

2010-02-22 17:58:06

WCF异步上传

2010-02-22 11:25:50

WCF DateSet

2010-02-24 15:20:23

WCF Message

2010-02-24 11:22:04

WCF方法重载

2010-02-23 17:30:41

WCF部署于IIS

2010-02-24 14:20:27

WCF并发模型

2009-12-21 17:40:25

WCF会话

2010-02-24 13:48:44

MSMQ使用WCF

2010-02-22 16:26:47

WCF传输数据
点赞
收藏

51CTO技术栈公众号