这篇文章主要介绍了IIS7报500.23错误的缘由分析及解决方法的相关资料,须要的朋友能够参考下
背景:今天公司终端上有一个功能打开异常,报500错误,我用Fiddler找到连接,而后在IE里打开,报500.23错误:检测到在集成的托管管道模式下不适用的ASP.NET设置。后台是一个IIS7和tomcat7集成的环境,此处记录一下。web
HTTP 错误 500.23 - Internal Server Errorwindows
检测到在集成的托管管道模式下不适用的 ASP.NET 设置。tomcat
为何会出现以上错误?测试
在IIS7的应用程序池有两种模式,一种是“集成模式”,一种是“经典模式”。日志
经典模式则是咱们之前习惯的IIS 6 的方式。blog
若是使用集成模式,那么对自定义的httpModules 和 httpHandlers 就要修改配置文件,须要将他们转移到和节里去。图片
两种解决方法:it
第一种方法、配置应用程序池io
在IIS7上配置应用程序池,而且将程序池的模式改成“经典”,以后一切正常。如图:dva
用了IIS7.x,但实际只发挥了6的功能,另外,在一些ASP.NET MVC程序中的效果也很差,因此,咱们尝试如下解决方法:
第二种方法、修改web.config配置文件:
注: web.config路径C:\inetpub\wwwroot\web.config
例如原先设置(你的环境中可能没有httpModules,httpHandlers节点)
复制代码 代码以下:
<system.web>
…
<add name=“MyModule"type=“MyApp.MyModule” />
<add path=”*.myh"verb="GET"type=“MyApp.MyHandler” />
</system.web>
在IIS7应用程序池为“集成模式”时,改成:
复制代码 代码以下:
<system.web>
…
</system.web>
<system.webServer>
<add name="MyModule"type=“MyApp.MyModule” />
<add name=“MyHandler"path=”*.myh"verb="GET"type="MyApp.MyHandler"preCondition=“integratedMode” />
</system.webServer>
(若是你的web.config没有httpModules,httpHandlers节点,则直接在节点system.webServer中添加:
复制代码 代码以下:
禁止验证集成模式,来避免错误。
IIS Log的位置
IIS 6.0的Log日志存储在:
c:\windows\system32\logfiles\
IIS 7 Log存储在:
%SystemDrive%\inetpub\logs\LogFiles
通过个人测试, IIS日志是即时写入的, 不须要IIS reset.
IIS 6, 7的日志写入按不一样站点写入不一样的文件夹, 位置文件夹的格式都是"w3svc{siteId}".
IIS6里, 查看站点ID的方式是经过IIS log的文件夹的名字来肯定Site ID.
IIS7中, 在IIS管理器中的advanced settings中, General里的ID就是Site ID, 而后你须要经过这个ID来定位LogFiles文件夹中哪个文件夹属于你要查看的站点.
文章来源:http://www.iis7.com/b/ssyqdq/