ASP.Net是一個非常強大的構建Web應用的平台,它提供了極大的靈活性和能力以致於可以用它來構建所有類型的Web應用。
絕大多數的人只熟悉高層的框架如: WebForms 和 WebServices --這些都在ASP.Net層次結構在最高層。
這篇文章的資料收集整理自各種微軟公開的文檔,通過比較 IIS5、IIS6、IIS7 這三代 IIS 對請求的處理過程, 讓我們熟悉 ASP.NET的底層機制 並對請求(request)是怎麼從Web服務器傳送到ASP.NET運行時有所了解。通過對底層機制的了解,可以讓我們對 ASP.Net 有更深的理解。
IIS 5 的 ASP.Net 請求處理過程
對圖的解釋:
IIS 5.x 一個顯著的特征就是 Web Server 和真正的 ASP.NET Application 的分離。作為 Web Server 的IIS運行在一個名為 InetInfo.exe 的進程上,InetInfo.exe 是一個Native Executive,並不是一個托管的程序,而我們真正的 ASP.Net Application 則是運行在一個叫做 ASPnet_wp 的 Worker Process 上面,在該進程初始化的時候會加載CLR,所以這是一個托管的環境。
ISAPI: 指能夠處理各種後綴名的應用程序。 ISAPI 是下面單詞的簡寫 :Internet Server Application Programe Interface,互聯網服務器應用程序接口。
IIS 5 模式的特點:
IIS6 的 ASP.Net 請求處理過程
對圖的解釋:
IIS 5.x 是通過 InetInfo.exe 監聽 Request 並把Request分發到Work Process。換句話說,在IIS 5.x中對Request的監聽和分發是在User Mode中進行,在IIS 6中,這種工作被移植到kernel Mode中進行,所有的這一切都是通過一個新的組件:http.sys 來負責。
注:為了避免用戶應用程序訪問或者修改關鍵的操作系統數據,Windows提供了兩種處理器訪問模式:用戶模式(User Mode)和內核模式(Kernel Mode)。一般地,用戶程序運行在User mode下,而操作系統代碼運行在Kernel Mode下。Kernel Mode的代碼允許訪問所有系統內存和所有CPU指令。
在User Mode下,http.sys接收到一個基於 ASPx 的http request,然後它會根據IIS中的 Metabase 查看該基於該 Request 的 Application 屬於哪個Application Pool, 如果該Application Pool不存在,則創建之。否則直接將 request 發到對應Application Pool 的 Queue中。
每個 Application Pool 對應著一個Worker Process:w3wp.exe,毫無疑問他是運行在User Mode下的。在IIS Metabase 中維護著 Application Pool 和worker process的Mapping。WAS(Web Administrative service)根據這樣一個mapping,將存在於某個Application Pool Queue的request 傳遞到對應的worker process(如果沒有,就創建這樣一個進程)。在 worker process 初始化的時候,加載ASP.NET ISAPI,ASP.NET ISAPI 進而加載CLR。最後的流程就和IIS 5.x一樣了:通過AppManagerAppDomainFactory 的 Create方法為 Application 創建一個Application Domain;通過 ISAPIRuntime 的 ProcessRequest處理Request,進而將流程進入到ASP.Net Http Runtime Pipeline。
IIS 7 的 ASP.Net 請求處理過程
IIS7 站點啟動並處理請求的步驟如下圖:
步驟 1 到 6 ,是處理應用啟動,啟動好後,以後就不需要再走這個步驟了。
上圖的8個步驟分別如下:
W3WP.exe 進程中又是如果處理得呢?? IIS 7 的應用程序池的托管管道模式分兩種: 經典和集成。 這兩種模式下處理策略各不相通。
本文作者:郭紅俊 http://blog.joycode.com/ghj
IIS 6 以及 IIS7 經典模式的托管管道的架構
在IIS7之前,ASP.NET 是以 IIS ISAPI extension 的方式外加到 IIS,其實包括 ASP 以及 PHP,也都以相同的方式配置(PHP 在 IIS 采用了兩種配置方式,除了 IIS ISAPI extension 的方式,也包括了 CGI 的方式,系統管理者能選擇 PHP 程序的執行方式),因此客戶端對 IIS 的 HTTP 請求會先經由 IIS 處理,然後 IIS 根據要求的內容類型,如果是 Html 靜態網頁就由 IIS 自行處理,如果不是,就根據要求的內容類型,分派給各自的 IIS ISAPI extension;如果要求的內容類型是 ASP.NET,就分派給負責處理 ASP.Net 的 IIS ISAPI extension,也就是 ASPnet_isapi.dll。下圖是這個架構的示意圖。
IIS 7 應用程序池的 托管管道模式 經典 模式也是這樣的工作原理。 這種模式是兼容IIS 6 的方式, 以減少升級的成本。
IIS6 的執行架構圖,以及 IIS7 應用程序池配置成經典模式的執行架構圖
IIS 7 應用程序池的 托管管道模式 集成模式
而 IIS 7 完全整合 .NET 之後,架構的處理順序有了很大的不同(如下圖),最主要的原因就是 ASP.NET 從 IIS 插件(ISAPI extension)的角色,進入了 IIS 核心,而且也能以 ASP.NET 模塊負責處理 IIS 7 的諸多類型要求。這些 ASP.NET 模塊不只能處理 ASP.NET 網頁程序,也能處理其他如 ASP 程序、PHP 程序或靜態 HTML 網頁,也因為 ASP.NET 的諸多功能已經成為 IIS 7 的一部份,因此 ASP 程序、PHP 程序或靜態 Html 網頁等類型的要求,也能使用像是Forms認證(Forms Authentication)或輸出緩存(Output Cache)等 ASP.NET 2.0 的功能(但須修改 IIS 7 的設定值)。也因為 IIS 7 允許自行以 ASP.NET API 開發並加入模塊,因此 ASP.NET 網頁開發人員將更容易擴充 IIS 7 和網站應用程序的功能,甚至能自行以 .Net 編寫管理 IIS 7 的程序(例如以程控 IIS 7 以建置網站或虛擬目錄)
IIS 7 的執行架構圖(集成托管信道模式下的架構)
小結
參考資料:
ASP.NET Process Model之一:IIS 和 ASP.Net ISAPI
http://www.cnblogs.com/artech/archive/2007/09/09/887528.Html
ASP.Net Internals – IIS and the Process Model
http://dotnetslackers.com/articles/IIS/
ASPNETInternalsIISAndTheProcessModel.ASPx
模組化的IIS 7 與.Net 能力整合
http://www.microsoft.com/taiwan/technet/columns/profwin/
33-IIS7-componentization-integration.mspx
Introduction to IIS 7.0 Architecture
http://learn.IIS.Net/page.ASPx/101/introduction-to-IIS7-architecture/