• 欢迎访问举个栗子网站
  • 小说APP下载 xsz.tw 不带广告的小说站

反代引起的IIS HTTP 错误 400.605 – Bad Request

网站 举个栗子 4周前 (10-19) 85次浏览 0个评论 扫描二维码

找了一篇文章。反正没有看懂这个。于是进服务器调整IIS 连接数试下。看了下。好像调整了也一样的效果。不知道怎么回事

iis 性能指标的各种概念:连接数、并发连接数、最大并发工作线程数、应用程序池的队列长度、应用程序池的最大工作进程数详解,感兴趣的同学参考下。

一般购买过虚拟主机的朋友都熟悉购买时,会限制IIS连接数,这边先从普通不懂代码用户角度理解IIS连接数

顾名思义即为 IIS 服务器可以同时容纳客户请求的最高连接数,准确的说应该叫“IIS 限制连接数”

这边客户请求的连接内容包括:

1、网站html 请求,html 中的图片资源,html 中的脚本资源,其他需要连接下载的资源等等,任何一个资源的请求即一次连接(虽然有的资源请求连接响应很快)

2、如果网页采用框架(框架内部嵌套网页请求),那么一个框架即一次连接

3、如果网页弹出窗口(窗口内部嵌套网页请求),那么一个窗口一个连接

虚拟主机供应商在 IIS(6.2 版本,以下所有截图均此版本)中  “点击网站”->“右击切换到功能视图”->“点击界面右侧的‘限制’链接”->“编辑网站限制”

反代引起的 IIS HTTP 错误 400.605 - Bad Request

 

限制连接数即为虚拟主机供应公开的 IIS 连接数标准,如果购买的 IIS 连接数为 50,那么我们不得不考虑网站的内容框架和访问量

如果网站图片够多,弹窗窗口随意(可能连时间选择框、简单条件筛选框也用弹出新窗口),加上不得已的打开新页面浏览内容,那么仅仅能容忍 10 个人同 时操作也很正常,我不会把这个操作描述为很多网站说的“10 同时在线”,这很容易让人误解,在用户的一次请求(表面上可能是刷新一次网页,实际上内部请求 不止一次,事实上很少只有一次)都完成得到服务器响应完毕之后,连接全部会被释放,当然在你看到展示的页面之前,内部嵌套如果有请求图片等连接请求,连接 会早早的被释放

事实上,很多企业门户网站访问量低的惊人,IIS 连接数为 50 也是绰绰有余了

 

IIS 并发连接数


 

“管理网站”->“高级设置”->”限制”->”最大并发连接数”

反代引起的 IIS HTTP 错误 400.605 - Bad Request

其实,普通用户常说的“IIS 链接数”就是这边的“最大并发连接数”,如果 PC 端有 IIS 的朋友,可以测试上面两个图片的设置,是相互影响的

这边默认最大并发连接数为:4294967295,这是一个很惊人的数字,难道这代表着网站能具有并发执行连接数为 4294967295 的能力?

这边我做几个假设:

1、很多虚拟主机供应商所说的无并发连接数限制真的成立吗?

2、每个连接的处理,IIS 都会开启一个线程去处理,假设这个处理方式成立,那么 4294967295 个并发连接请求来了是否 IIS 会立即启动 4294967295 个线程去处理?

 

对于 1:很显然不成立,最大并发连接数的设置绝对有上限

对于 2:这是很多朋友的误区,假设 4294967295 并发连接同时来了,IIS 不会立即启动 4294967295 个线程去处理,因为这不现实,对于处理连接,IIS 是有“最大并发工作线程数”限制的,这是我下面要介绍的,我从一些资料上查阅到,该数字跟操作系统相关,win7 系统的 IIS 的值是 10(或者其他不确定),VS2012 自带的 IIS Express 的值是 80。对于 windows 服务器版本的系统的具体值不清楚,即 4294967295 个并发连接来了后,(这边以 win7 下的 10 为例),iis 第一时间只能启动 10 个工作线程去处理,那么其他 4294967285必须排队,排队对用户的体验来说就是网页正在加载,但是什么都不显示,然后此时购买了据虚拟主机供应商所说的无并发连接数限制的客户就要开始狂暴了,为何购买了所谓的“无限并发连接数”,还是会一直在加载的情况,我只能说这就是 IIS 处理能力有限的问题了

 

当然服务器没有直接返回“HTTP Error 503. The service is unavailable.”应该也算是一些你花更多钱的安慰吧,因为你只购买了 IIS 连接数为 50 的话,那么第 50+1 个连接请求操作得到的就直接是 “HTTP Error 503. The service is unavailable.”了

另外,如果 web 服务器的硬件设备够爽朗(牛逼),那么 IIS 的工作线程也会处理的更快,那么响应的用户等待的时间也会更短(前提是你的 IIS 连接数够大哦,否则就直接 503 了哦)

总的来说,最大并发连接数,影响了排队的数量,

很多时候需要我们评估自己的网站的最大并发连接数,然后来进行设置最佳数量

 

IIS 最大并发工作线程数


 

这个在上面有所涉及,简单的说就是 IIS 在并发连接请求过来时的处理机制,它会更机智的以某个数量级为单位来分批处理,让没有处理连接请求排队等待,用户浏览器中对于排队等待的响应就是“正在加载”,这比页面直接显示“HTTP Error 503. The service is unavailable.”更加能让人接受,但是切勿气急败坏的怒点刷新按钮,因为点的越多,你的请求在排队队伍中越靠后。

当然很多朋友会说,为什么我有时候第一次刷不出来,重新多刷一次内容就出来了,

可能是:

1、页面脚本哪个地方下载或者处理出了问题,导致页面显示异常或者直接不显示

2、你重新刷新的那个秒级别的操作,web 服务器更快速的已经处理好了其他队列的请求或者他人放弃了对 web 服务器连接请求的操作

3、路由或者宽带网络运营商问题(不稳定)

4、浏览器或者本身电脑问题

我不知道“IIS 最大并发工作线程数”有无地方可以设置,知道的朋友可以给我留言,谢谢

那么现在问题来了,最大并发连接数,影响了排队的数量,那么有没有进步影响排队数量的设置? 有的:队列长度

 

队列长度


 

假设最大连接数设置为 100,1000 个并发连接请求过来了,首先 900 直接返回给客户“HTTP Error 503. The service is unavailable.”

然后 IIS 先启动(假设最大并发工作线程数为 10)10 个线程处理请求,其他 90 个进入排队状态,如果此时如下操作:

找到网站的所属应用程序池,“右击高级设置”->”常规”->”列队长度”,设置为 20

反代引起的 IIS HTTP 错误 400.605 - Bad Request

那么实际情况又会变成什么样子呢?只会有 20 个进入排队状态了,70(90-20)个请求也会立刻返回“HTTP Error 503. The service is unavailable”

iis 默认队列长度设置是 1000,范围在 10-65535 之间

 

最大工作进程数


 

IIS 6.0 允许将应用程序池配置成一个 Web 园(Web Garden)

找到网站的所属应用程序池,“右击高级设置”->”进程模型”->”最大工作进程数”,默认 1

反代引起的 IIS HTTP 错误 400.605 - Bad Request

如果这个值大于 1,那么当有连接请求时会启动多个新的工作进程实例,可启动的最多进程数为您所指定的最大工作进程数,后续更多的请求将以循环的方式发送至工作进程,这个 每个工作进程都能承担负载一些连接请求,当然是以消耗 cpu 等硬件做代价,这是值得的,如果 web 服务器 cpu 使用率很低但是又需要更高效的处理并发连接 请求,为何不这么做呢?

如果网站中用到了依赖进程的 Session 和 Cache 等对象,则不能保存在服务器内存中,存储方式选用 StateServer 或者 SQLServer 会更好,另外多个工作进程切换时会有上下文复制,这也是资源消耗更多地方

最大工作进程数的设置方法:(拷贝)按照每工作进程能承载 30 个并发的原则来确定应用程序池的最大工作进程数。同时要注意,每个工作进程大约会占用 200M 左右的系统内存,在设置最大工作进程数的时候,要主要最大工作进程数与 200M 的乘积不要超过系统最大可用内存数。一般情况下,建议按照每次增加 5 个工作进程数的方式对最大工作进程数进行调整,调整完后对网站观察一段时间,如依然无法满足要求,再继续增加 5 个工作进程数。


举个栗子 , 版权所有丨如未注明 , 均为原创丨本网站采用BY-NC-SA协议进行授权
转载请注明原文链接:反代引起的 IIS HTTP 错误 400.605 – Bad Request
喜欢 (0)
举个栗子
关于作者:
建筑工地上施工员,闲暇时弄个博客打发时间,
发表我的评论
取消评论
表情 贴图 加粗 删除线 居中 斜体 签到

Hi,您需要填写昵称和邮箱!

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址