WCF和流式传输大数据

时间:2014-10-02 09:47:47

标签: performance wcf streaming

我在wcf(演出)中使用大数据。我需要将它返回给客户端,之前的代码编写了一个内存流,然后将其作为流数据协定的属性返回给客户端。

问题是数据已经增长,内存流现在使用所有可用内存,并且最终在将所有数据写入流之前失败。

是否可以按需将数据写入流中,因此服务器正在写入客户端正在请求的数据?

1 个答案:

答案 0 :(得分:0)

这是我们的代码;

internal  StreamedFileResponse CreateStream()
{
    var stream = new MemoryStream();

    using (var writer = new CsvWriter(stream, Encoding.UTF8))
    {
        writer.Write(rowFactory.CreateHeader());

        foreach (var source in sources)
        {
            var row = rowFactory.Create(source);
            if (row != null)
            {
                writer.Write(row);
            }
        }
    }

    stream.Seek(0, SeekOrigin.Begin);

    return new StreamedFileResponse { Data = stream, Length = stream.Length };
}

[MessageContract(WrapperNamespace = "http://www.contoso.com/services/contract/reports/streamed")]
public class StreamedFileResponse : IDisposable
{
    [MessageBodyMember]
    public Stream Data { get; set; }

    [MessageHeader(MustUnderstand = true)]
    public long Length { get; set; }

    public void Dispose()
    {
        Data.Dispose();
    }       
}