加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 编程开发 > asp.Net > 正文

ASP.NET如何确定是否排队请求?

发布时间:2020-12-15 20:18:26 所属栏目:asp.Net 来源:网络整理
导读:当ASP.NET接收到请求时,它如何确定是服务还是排队?我问,因为我正在监控服务器上的性能计数器,并且CPU没有超出,并且有一大堆可用的工作线程,但我仍然看到最多200个请求排队. 解决方法 我一直在做研究,我相信我得到了一个可以接受的答案.我的主要来源是这篇文
当ASP.NET接收到请求时,它如何确定是服务还是排队?我问,因为我正在监控服务器上的性能计数器,并且CPU没有超出,并且有一大堆可用的工作线程,但我仍然看到最多200个请求排队.

解决方法

我一直在做研究,我相信我得到了一个可以接受的答案.我的主要来源是这篇文章: http://blogs.msdn.com/b/tmarq/archive/2007/07/21/asp-net-thread-usage-on-iis-7-0-and-6-0.aspx

据了解,请求处理有两种主要方式被限制.第一个是MaxConcurrentRequestsPerCPU属性.在.NET 4之前,这个默认设置为12.在.NET 4中,它被更改为5000.对于异步请求,他们希望允许很多,而对于同步请求,他们认为ASP.NET ThreadPool会足够节制同步请求.第二个是ThreadPool本身. ASP.NET发布请求后,可以决定何时进行.

如果您正在进行异步处理,您的限制因素可能是CPU,网络和磁盘,而不是任何ASP.NET请求限制.它可能会达到MaxConcurrentRequestsPerCPU限制,但是这个限制真的很高.

如果您在长时间的网络呼叫中进行同步处理和阻止,则更有可能遇到这些限制. MaxConcurrentRequestsPerCPU在.NET 4之前需要注意,但仍然有ThreadPool.

性能测试
我把一个简单的测试放在一起,看看这个节流是如何工作的.我有一个简单的页面,带有一个500ms的Thread.Sleep()调用.一台主机同时发出800个异步请求,运行ASP.NET的工作机器全部进行处理.结果很有趣:

.NET 3.5,没有修改:46秒.用过程浏览器查看9个工作线程.
.NET 3.5,MaxConcurrentRequestsPerCPU设置为5000:46秒. 9个工作线程.
.NET 4:42秒,或运行热时13秒.看到35个工作线程逐渐创建.
.NET 4,异步:3秒

几点意见:

> MaxConcurrentRequestsPerCPU没有受到打击.它看起来像是ThreadPool本身的限制..NET 3.5似乎并不愿意让新线程来处理同步请求. .NET 4做了更好的工作来加快处理负载.>异地仍然是国家一英里最好的.

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读