gpt4 book ai didi

wcf - 同一服务器内 WCF Web Services 的通信时间长

转载 作者:行者123 更新时间:2023-12-04 21:39:21 24 4
gpt4 key购买 nike

即使这个问题已经存在一年了,我仍在为这个问题寻找一个好的答案。我很感激任何能让我完全理解这个关于同一台机器上托管的通信 Web 服务性能低下的问题的信息。

我目前正在开发一个系统,其中包含几个密集通信的 WCF Web 服务。
它们在 IIS7 下运行,在同一台机器上,每个服务都在不同的应用程序池中,在 Web Garden 中有多个工作人员。

在对每个 Web 服务进行单独评估期间,我可以每分钟快速处理 10000-20000 个请求,并且没有任何资源消耗(处理器和内存)问题。

当我测试整个系统或仅测试由两个 Web 服务组成的子系统时,我无法提供超过 2000 个请求/分钟的服务。
我还观察到 Web Service 之间的通信时间是一个大问题(有时超过 10 秒)。但是当测试每分钟只有 1000 个请求时,一切都很顺利(连接时间不超过 60 毫秒)。
我已经使用 SOAPUI 和 JMETER 测试了系统,但时间是根据系统日志计算的,而不是根据测试工具计算的。
内存和网络不是问题(它们很少使用)。

稍后,我测试了 2 个通信 WCF Web 服务的性能,托管在两台服务器和同一台服务器上。当服务在同一台机器上时,似乎又出现了瓶颈,将连接数从一万降低到数千;同样,没有内存或处理器限制。

作为说明,在某些情况下,我正在处理相当大的数据,并且需要的一些操作很长。

我使用 perf.mon 查看内存、进程、webservice、aspnet 等发生了什么,但我没有看到任何可以表明它出了什么问题的东西。
我还尝试了在 Internet 上可以找到的所有性能设置和调整选项。

有人知道有什么问题吗?为什么 Web Services 之间的通信可以持续这么长时间?为什么作为系统入口点的Web Service在单独测试时可以接受10000个请求/分钟,而与另一个Web Service通信时几乎不能接受2000个请求?
这是IIS7的问题吗?如果每个 Web 服务都部署在不同的服务器上,我的系统会表现得更好吗?

我想更好地了解事物的内部功能(IIS 和 WCF 服务)如何提高当前和 future 系统的性能。

最佳答案

您可以尝试从 WCF 性能计数器收集数据:并发调用、实例、持续时间……此外,WCF 限制提供了一些属性,您可以使用这些属性来限制在应用程序级别创建的实例或 session 的数量。 WCF 服务的性能可以通过创建适当的实例来提高。
最后,在负载测试中,有许多配置适用于不同的组件:最大并发 http 连接、IIS 限制、拥有许多负载客户端……因此,您的负载测试无效。

关于wcf - 同一服务器内 WCF Web Services 的通信时间长,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/9583608/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com