新聞中心
在 IIS 7.5 中,應用程序池有兩種運行模式:集成模式和經典模式。

應用程序池模式會影響服務器處理托管代碼請求的方式。
如果托管應用程序在采用集成模式的應用程序池中運行,服務器將使用 IIS 和 ASP.NET 的集成請求處理管道來處理請求。
如果托管應用程序在采用經典模式的應用程序池中運行,服務器會繼續(xù)通過 Aspnet_isapi.dll 路由托管代碼請求,其處理請求的方式就像應用程序在 IIS 6.0 中運行一樣。
經典模式:
指的是與IIS 6或者之前版本保持兼容的一種模式,一個典型問題就是,在處理ASP.NET這種動態(tài)網站的時候,它是通過一個所謂的ISAPI程序,作為插件的方式來工作的。針對不同的動態(tài)應用程序(例如ASP,PHP等),會需要不同的ISAPI。
集成模式:
這種全新的模式,允許我們將ASP.NET更好地與IIS集成,甚至允許我們在ASP.NET中編寫一些功能(例如Module)來改變IIS的行為(擴展)。集成的好處是,不再通過ISAPI的方式,提高了速度和穩(wěn)定性。至于擴展,則可以使得我們對于IIS以及其他類型的請求有更多的控制。
升級過程中出現了比較多的問題,前面文章也提到過幾個。這次就主要介紹下httpHandler 和 httpModule 在集成和經典模式下的區(qū)別。很多文件上傳等都是需要使用到httpModule去實現。我今天就出現了NeatUpload在iis7.5下出現未將對象引用到設計實例的錯誤。所以用httpModule作為測試案例。
1.新建測試網站WebApplication,加入MyHttpModule類實現IHttpModule接口,主要目的是測試程序是否經過了HttpModule,經過的在頁面輸出HttpModule字符。
public class MyHttpModule : IHttpModule
{
public void Dispose()
{
}
public void Init(HttpApplication context)
{
context.BeginRequest += context_BeginRequest;
}
protected void context_BeginRequest(object sender, EventArgs e)
{
var context = sender as HttpApplication;
context.Response.Clear();
context.Response.Write("HttpModule");
context.Response.End();
}
}
2、2.在IIS7.5部署網站,首先使用經典模式應用程序池。在web.config的
訪問網站可以發(fā)現頁面輸出如下,說明程序經過了HttpModule
直接切換應用程序池成集成模式會發(fā)現頁面輸出為空。證明程序沒有經過HttpModule。那在集成模式下HttpModule如何才能執(zhí)行呢? 之前部署URLRewriter的時候查資料只知道需要
這樣就大概明白意思是iis7.0之后有部分web配置移動到system.webServer中。查閱相關得到答案確實如此 詳細資料見 http://www.cnblogs.com/buaaboyi/archive/2011/01/20/1939903.html
于是在
由于在升級過程成有一個站點出現 HTTP 錯誤 500.22 - Internal Server Error 檢測到在集成的托管管道模式下不適用的 ASP.NET 設置
當時在比較急的情況下就直接刪除了
經過這今天的折騰終于是對iis7.5上的部署有了一定了解了。
分享名稱:IIS7.5應用程序池集成模式和經典模式的區(qū)別介紹
鏈接分享:http://m.5511xx.com/article/cdjscoj.html


咨詢
建站咨詢
