【发布时间】:2012-06-14 19:49:31
【问题描述】:
我们一直在客户站点看到随机的 OutOfMemoryExceptions 和 InsufficientMemoryExceptions。我们使用 GZipMessageEncoder 来压缩消息。 (我知道IIS 7.x compression 选项和other problems with buffering and/or the GZipMessageEncoder。)
我想尝试启用 WCF 流。我们的 WCF 服务具有如下合同:
[OperationContract]
DataSet GetDataSet(Guid someGUID, string someName, DataSet parameters);
流式传输中发生的操作最多可以与一个输入或输出参数签订合同
显然,我们的合同违反了 WCF 流式传输限制。该合约有 3 个输入参数。
但是,出于好奇,我还是决定尝试启用流式传输。我编辑了 web.config 文件和 MyCSharpClient.config 文件,并将以下属性插入到绑定的传输部分:
<httpTransport ... transferMode="Streamed">
令我惊讶的是,一切似乎都正常!没有抛出异常。我可以闯入 GZipMessageEncoder 并验证正在调用流方法而不是缓冲区方法。
那么,我的问题是:为什么我能够在违反 WCF 输入参数限制的操作上下文上设置流传输?鉴于 MSDN 流媒体文章的措辞强硬,我认为这只是一个实现细节,我绝不能依赖这种行为。
【问题讨论】:
-
我不知道答案,但请检查这里是否重复:stackoverflow.com/questions/6094342/…
-
不同的问题。我了解如何捆绑参数以满足 1 个输入参数的 MSDN 规范。我只是想知道这些限制是否真的被强制执行,如果我确实违反了 WCF 限制,我会看到什么样的错误。
-
既然绑定参数很容易,为什么还要冒险呢?
-
因为部署新界面本身就是一个挑战。