這篇文章主要介紹了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/