http://bb s.falo o.c om/doc/104990/1.html
当你访问博客园出现“Server Error in'/'Applic ation.Runtime Error.”的错误时你知道这个错误的背后是什么吗?你也许会想博客园怎么不设计个定制错误页面这样的错误页面让访问者不知所措只能抱怨“服务器出问题了”。当出现这个问题时我急啊!真想站到互联网上拿着大喇叭对大家喊我刚更新了程序或者修改了web.c onfig的设置 asp.net在进行首次编译在编译的同时还要处理大量的请求忙不过来只能拒绝请求实际的错误信息是"Server Too Busy"错误来自HttRuntime的Rej ectRequestInternal方法。你也许会说用c us tomErrors页面处理一下啊可是HttRunt ime 已经拒绝了这个请求 重定向到defaultRedirect定制错误页面还是被拒绝结果就出现“Server Error in'/'Application.RuntimeError.”错误。这个问题困扰我很长时间当更新程序(或者修改web.c onfig的设置、应用程序池回收、 IIS重启)时就会出现这个问题尤其是访问高峰期要几分种才能恢复正常郁闷!要是在这时显示一个友好的错误显示页面那该多好啊!今天晚上更新程序时又遇到这个问题。我再次下决心要解决这个问题。
要解决问题首先要分析出为什么会出现问题。既然是HttRuntim e抛出的异常那就从HttRunt ime下手。怎么下手呢用强大的Reflec tor工具微软这点做的不错很多.NET类库都可以通过Reflec tor工具查看源代码。通过分析HttRunt ime的源代码我找到了问题的原因这里我简单地描述了一下
做人要厚道转载请注明来自飞卢(faloo.com)
Re:定制“Server Too Busy”错误信息
接着就是异常的处理 向客户端浏览器显示异常信息调用FinishRequest,在Finish中调用c ontext.Re s p ons e.Rep ortRuntimeError(e, true)显示异常信息 Rep ortRuntime Error会根据w eb.c onfig中的CustomErrors设置决定是否重定向到defaultRedirect。
当你设置CustomErrors 的 defaultRedirect来定制处理异常信息时 如果遇到"Se rve r_too_busy"就麻烦了重定向到错误处理页面后又被HttpRuntime拒绝拒绝后又被重定向到defaultRe dire ct页面 HttpRuntime 《———》HttpRuntime.....似乎进入了一种恶性循环。原来问题有这么严重写文章之前我还没想到写到这我才发现。这样不停的来回C PU岂不累死当C PU累的不行时就随便抛出一个其他异常:)也就是“S e rve rError in'/'Application.Runtime Error.”这个异常我没找到在哪抛出的。难道在首次编译时 C PU占用很高与这个也有关系。我更新博客园服务器上的程序时要几分钟才能恢复正常而这时C PU基本是满负荷工作难道也是这个问题引起我想明天在访问高峰期测试一下就能得到证实。这似乎是设计者的一个疏忽 正确的做法应该是对于"Se rve r_too_busy"异常不管用户是否设置了 defaultRedire ct,都不应该去重定向到defaultRedirect而是直接向客户端发送异常信息这是一个很特殊的情况设计者在设计
DogYun怎么样?DogYun是一家2019年成立的国人主机商,称为狗云,提供VPS及独立服务器租用,其中VPS分为经典云和动态云(支持小时计费及随时可删除),DogYun云服务器基于Kernel-based Virtual Machine(Kvm)硬件的完全虚拟化架构,您可以在弹性云中,随时调整CPU,内存,硬盘,网络,IPv4路线(如果该数据中心接入了多条路线)等。DogYun弹性云服务器优...
Hostodo是一家成立于2014年的国外VPS主机商,现在主要提供基于KVM架构的VPS主机,美国三个地区机房:拉斯维加斯、迈阿密和斯波坎,采用NVMe或者SSD磁盘,支持支付宝、PayPal、加密货币等付款方式。商家最近对于上架不久的斯波坎机房SSD硬盘VPS主机提供66折优惠码,适用于1GB或者以上内存套餐年付,最低每年12美元起。下面列出几款套餐配置信息。CPU:1core内存:256MB...
RackNerd今天补货了3款便宜vps,最便宜的仅$9.49/年, 硬盘是SSD RAID-10 Storage,共享G口带宽,最低配给的流量也有2T,注意,这3款补货的便宜vps是intel平台。官方网站便宜VPS套餐机型均为KVM虚拟,SolusVM Control Panel ,硬盘是SSD RAID-10 Storage,共享G口带宽,大流量。CPU:1核心内存:768 MB硬盘:12 ...