3

在NewRelic stream & writeHeaders上提出了类似的问题

WCF在 New Relic 上分析我的服务。有一个WCF服务调用另一个WCF服务。现在我想在调用另一个 WCF 服务时,当它创建请求时,内部进程在某处将标​​头写入请求流,这有时很慢。我在 New Relic 中找到的跟踪告诉我,对于我的一个 WCF 服务的特定方法调用我的另一个WCF服务的方法,大约需要50-60几秒钟,其中95-100 %的时间由 System.Net.ConnectStream.WriteHeaders 消耗。

Stream[url of WCF service/soap]: WriteHeaders -> 99.78 % time (approx 49 seconds).

我没有得到它是什么以及如何减少这个时间?

我已经搜索过,但没有找到 ConnectStream 实际做了什么或有关它的一些细节,因此我可以找到任何方法来减少它所花费的时间。

请让我知道你的建议。

4

2 回答 2

0

当您调用的服务停止或被太多并发连接淹没时,我之前也看到过同样的情况。如果问题是前者,分析您的 WCF 服务可能有助于确定根本原因 - 可能由于数据库访问或其他一些 I/O 绑定进程而导致响应缓慢。如果问题是后者,您可以通过调整服务的性能来解决问题 ( http://msdn.microsoft.com/en-us/library/ee377061(v=bts.10).aspx )

这也可以表现为 New Relic 中 ASP.NET 应用程序的“BeginRequest”。BeginRequest 或 WriteHeaders 很少表示问题确实出在发送数据本身,尽管如果您的有效负载很大,但在传输数据很小的常规调用中,会出现连接时间慢或响应慢的问题在这两个领域。

于 2013-07-23T17:06:27.337 回答
0

听起来您正在从客户端流式传输一个大文件,在一个 WCF Web 服务中捕获它,然后将数据重新写入新的 HttpWebRequest,然后将其发送到另一台主机。我想我很想尝试将数据从客户端缓冲到您的 Web 服务而不是流式传输。

去年我一直在从事一个听起来与您正在做的事情相似的项目。流式传输和缓冲之间的区别是:

流式读取(从源)然后在交互过程中写入(到目标)数据,您没有太多控制权。如果源文件很大(例如 gig 或更多),WCF 请求/响应将在请求完成之前在客户端和主机之间来回迭代十几次或更多次。

另一方面,缓冲在填充请求并将其发送到主机之前累积目标文件的全部内容,从而加快处理速度。并且由于缓冲(在内存中累积字节所需的时间)导致的性能损失被放置在客户端上,因此通常不是问题。

因此,当从客户端缓冲数据时,您的主机将收到一个带有完整字节数组(比方说)的 Http 请求,该请求已准备好重新打包到您传递到第二个目标 WCF 主机的请求中。在这一点上,您可以再次在缓冲和流式传输之间进行选择。在主机上,性能很重要,将请求流式传输到第二台主机将提高您的可伸缩性,但(再次)可能会损害您的性能速度。

在客户端:

    With binding
      .TransferMode =TransferMode.Buffered 'instead of Transfermode.Streamed                                                              
      .MessageEncoding = WSMessageEncoding.Text
      .TextEncoding = System.Text.Encoding.UTF8
      .MaxReceivedMessageSize = Integer.MaxValue
      .ReaderQuotas.MaxArrayLength = Integer.MaxValue
      .ReaderQuotas.MaxBytesPerRead = Integer.MaxValue
      .ReaderQuotas.MaxDepth = Integer.MaxValue
      .ReaderQuotas.MaxNameTableCharCount = Integer.MaxValue
      .ReaderQuotas.MaxStringContentLength = Integer.MaxValue
      .MaxBufferSize = Integer.MaxValue
      .MaxBufferPoolSize = Integer.MaxValue

在主机方面:

With binding
      .TransferMode = TransferMode.Buffered
      .MaxReceivedMessageSize = Integer.MaxValue
于 2013-04-19T09:49:52.747 回答