最近公司项目的服务器出现了性能问题,关于iis负载过大,当客户问到最大链接数相关问题形成很萌的感受,就查了相关资料:php
首先让咱们来看看IIS里面的这2个数字:最大并发链接数,队列长度。先说这2个数字在哪里看。html
最大并发链接数:在IIS中选中一个网站,右键网站名称,在右键菜单中找到并点击【管理网站】->【高级设置】。打开对话框以下图:数据库
队列长度:在IIS中选中【应用程序池】,在应用程序池列表中,右键你想查看的,在右键菜单中选择【高级设置】。打开以下对话框:windows
这两个数字表面上看是影响咱们站点的并发处理能力的,可是具体是如何影响一个网站的并发处理能力的呢?要彻底理解IIS的并发处理能力,除了这2个数字,实际上还有一个很是关键的数字:IIS最大并发工做线程数。服务器
在之前很长一段时间,我一直觉得IIS的【最大并发链接数】就是影响IIS最大并发工做线程数。我觉得将【最大并发链接数】设置为1万,那么当1万个请求同时到来的时候,IIS会开启1万个线程进行处理,若是同时到来2万个请求,因为最大并发链接数只有1万,那么剩余1万个请求就会放在队列里面,当前面的1万个线程中某个完成了请求以后,再从队列里面取一个请求。但,这个理解是彻底错误的,相信不少朋友也跟我有一样的理解。网络
如今,首先让咱们来理解什么是【IIS最大并发工做线程数】。这个数字在IIS里面是没有界面进行设置的,我之前根本就不知道有这个数字。这个数字跟操做系统相关,个人win7系统的IIS的值是10,VS2012自带的IIS Express的值是80。对于windows服务器版本的系统的具体值是多少没有测试过,但我猜应该也是有限制的。并发
这个数字究竟是什么意思呢?回到上面举的例子,当1万个请求同时进入IIS的时候,因为win7系统的IIS只有10个工做线程,那么这时1万请求中只有10个请求会在第一时间被处理,剩余9990个请求都须要排队。也就是说,IIS最多可以安排10个线程同时处理请求(win7版本的IIS,有的多是20)。性能
因此,若是你用本身的win7系统测试IIS的性能的时候,你可能发现,无论你怎么设置【最大并发链接数】,你的IIS处理能力都颇有限。测试
上面讲的IIS最大并发工做线程数,看上去就是IIS的并发处理能力,若是是这样,那么【最大并发链接数】有什么意义呢?网站
仍是上面的例子,若是1万个请求同时到来,而咱们的win7系统的IIS最大并发工做线程数只有10,这时若是将【最大并发链接数】设置为100,会有什么效果呢?答案是:只有100个请求会收到正常响应,剩余9900个请求直接返回503(服务不可用)的错误。这时,实际上进入排队等待的只有90个请求。
再换下测试参数,若是将【最大并发链接数】设置为5000,又会有什么效果?答案你可能已经知道了,那就是一开始就有5000个请求直接返回503,剩下5000个请求慢慢正常返回。
这里你看明白了吧,【最大并发链接数】在咱们的测试例子中,影响到了排队的数量。这样的话,看上去【队列长度】又不知道什么意思了?
在上面的例子中,若是1万个请求同时到来,【最大并发链接数】设置为100。这时咱们知道,IIS首先会安排那10个线程去处理10个请求,剩下90个请求都须要排队。这时若是咱们将【队列长度】设置为50,那会出现什么状况?答案是,40个请求会直接返回503服务不可用的错误(由于队列只有50个的长度,剩下的40个就没法排队了),最终只有60个请求会被正确处理。
读到这里,你明白了吗?
当不少请求同时到来的时候,IIS会根据【最大并发链接数】来判断是否有多余的请求,多余的请求直接返回503,而后再根据【队列长度】来判断是否有多余的请求排不了队,排不了队的也直接返回503。因此,如何设置【最大并发链接数】和【队列长度】,其实是有公式能够计算的:
最大并发链接数 = 队列长度 + IIS最大并发工做线程数
最后再说说IIS的默认值对咱们网站并发处理能力的影响。IIS默认的【最大并发链接数】为4294967295(42亿多),而【队列长度】默认值为1000。对于windows server版本的IIS,最大并发工做线程数可能几百(猜想,可能没有限制),按照这个默认值,那么IIS同时处理的请求数也就1000多。1000多这个数字才是IIS真正的并发处理能力,而这个能力跟咱们的代码没有关系。那么哪些指标是评判咱们网站的处理能力的呢?最重要的指标可能莫过于【每秒处理请求数】吧(在性能分析器里面能够查看),这个数字也叫吞吐率。若是每一个请求处理速度很是快,那么那么网站吞吐率就大,吞吐率大那么支持的同时在线人数就大。若是要作秒杀,那就看你的秒杀相关的URL支持多大的吞吐率吧。了解了这么多指标,尚未涉及到CPU的计算能力。CPU的计算能力是如何影响网站的处理能力的呢?仍是那么多请求,若是CPU很强大,可以缩减每一个请求的处理时间,那必然会提升吞吐率。还有不少的请求,若是花在网络传输或者到数据库的传输时间比较多,这部分等待时间CPU是闲置的,若是可以提升CPU的利用率,也可能提升网站的处理能力,最充分的利用服务器的资源。若是不想改代码而想提升CPU利用率,能够在IIS的应用程序池中设置最大工做进程数(默认值为1),能够设置为10若是当前CPU利用率只有百分之几的话,调整这个数值须要特别注意每个工做进程是独立的应用程序,全局静态变量不共享。