我们一直在客户站点看到随机的 OutOfMemoryExceptions 和 InsufficientMemoryExceptions。我们使用 GZipMessageEncoder 来压缩消息。(我知道IIS 7.x 压缩选项以及缓冲和/或 GZipMessageEncoder 的其他问题。)
我想尝试启用 WCF 流。我们的 WCF 服务具有如下合同:
[OperationContract]
DataSet GetDataSet(Guid someGUID, string someName, DataSet parameters);
根据MSDN 上的这篇文章:
流式传输中发生的操作最多可以有一个输入或输出参数
显然,我们的合约违反了 WCF 流的限制。该合约有 3 个输入参数。
但是,出于好奇,我还是决定尝试启用流媒体。我编辑了 web.config 文件和 MyCSharpClient.config 文件,并将以下属性插入到绑定的传输部分:
<httpTransport ... transferMode="Streamed">
令我惊讶的是,一切似乎都正常工作!没有抛出异常。我可以闯入 GZipMessageEncoder 并验证是否正在调用流方法而不是缓冲区方法。
所以,我的问题是:为什么我能够在违反 WCF 输入参数限制的操作上下文上设置流传输?鉴于 MSDN 流媒体文章的措辞强硬,我认为这只是一个实现细节,我绝不能依赖这种行为。