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。
新聞熱點
疑難解答
圖片精選