asp.net mvc 站点优化
基于上篇:IIS网站日志分析
现象
服务端:IIS 日志,
#Fields: date time s-ip cs-method cs-uri-stem cs-uri-query s-port cs-username c-ip cs(User-Agent) cs(Referer) sc-status sc-substatus sc-win32-status time-taken
2017-02-07 04:26:43 10.173.17.106 POST /RunStatus/AddFlowMsg - 8088 - 10.165.124.2 - - 200 0 0 218
2017-02-07 04:26:53 10.173.17.106 POST /RunStatus/AddFlowMsg - 8088 - 10.171.127.232 - - 200 0 64 61094
客户端:爬虫异常日志,
The operation has timed out
由于爬虫设置超时时间为60秒,根据sc-win32-status:64 , time-taken:61094
1. 客户端提前断开,就会看到scStatus=200,scwin32status=64
2. 正常,我就会看到scStatus=200,scwin32status=0
可以看出:60秒后,客户端不愿意等了,所以请求超时。
分析:
真对上述问题,查看阿里云服务器状态:内存,CPU使用率都很低,由于是内网,带宽没问题。
什么原因呢? 我觉得是服务器没利用起来。
后来找到这篇文章:https://msdn.microsoft.com/zh-cn/library/ee728598(v=vs.100).aspx
这可能不是一个问题,因为线程池可以设置得足够大以容纳许多阻塞的线程。 但是,线程池中的线程数目是有限制的。 在同时处理多个长时间运行的请求的大型应用程序中,可能会阻塞所有可用的线程。 这种情况称为“线程不足”。 当出现这种情况时,Web 服务器会将请求排队。 如果请求队列已满,则 Web 服务器会拒绝请求并处于 HTTP 503 状态(服务器太忙)。
在调用异步操作时,将执行以下步骤:
Web 服务器从线程池(辅助线程)获取一个线程并安排它处理传入请求。 此辅助线程启动一个异步操作。
将此辅助线程返回到线程池以对另一个 Web 请求提供服务。
在异步操作完成时通知 ASP.NET。
Web 服务器从线程池获取一个线程(可能是与启动异步操作的线程不同的线程)以处理请求的其余部分,包括呈现响应。
我的理解:
asp.net 线程池里面的线程数是固定的,我们把它们理解我服务台的窗口服务人员,
1,同步,它们既要接受客户端请求,又要处理业务。就如同窗口服务人员在等到客户办理业务时,自己去后面处理好在交给客户,一个人把一套流程走完。
2,异步,asp.net 线程池里面的线程只负责接受和应答。就如窗口人员等到客户来办理业务,然后给后台具体负责此业务的工作人员去处理,自己继续受理其它客户的业务,等到工作人员处理完了,再给任意一个
窗口服务人员,让他交给具体客户。
由上看出,我们把工作人员,及后台工作线程给利用起来了。
好了,那么我们就改成异步的吧,经过改造成异步控制器,CPU和内存立马飙上去了,再也没有客户端响应超时了 。
最新文章
- Java中普通代码块,构造代码块,静态代码块区别及代码示例
- MVC4相关Razor语法浅谈
- Python打包成exe程序
- MVC中的自定义控件——分页
- 第三篇 SQL Server安全主体和安全对象
- D.xml
- 【设计模式六大原则2】里氏替换原则(Liskov Substitution Principle)
- zabbix3.0.3 设置邮件报警
- bindiff 4.2使用
- 新ITC提交APP常见问题与解决方法(Icon Alpha,Build version,AppIcon120x120)(2014-11-17)
- UTF-8 的BOM带来的麻烦
- 洛谷 P2590 [ZJOI2008]树的统计
- Git 安装和使用教程
- 你不知道的JavaScript-2.词法作用域
- Unity3D鼠标坐标转世界坐标和局部坐标
- Python面向对象编程-类的封装,继承、多态
- windows7 安装虚拟机,xsheel连接不上的问题,记录一下
- Oracle 修改字段顺序的两种方法
- 基于Windows 机器学习(Machine Learning)的图像分类(Image classification)实现
- Egret第三方库的制作和使用(模块化 第三方库)