各版本IIS下ASP.net請求處理過程分析第1/3頁
絕大多數(shù)的人只熟悉高層的框架如: WebForms 和 WebServices --這些都在ASP.NET層次結(jié)構(gòu)在最高層。
這篇文章的資料收集整理自各種微軟公開的文檔,通過比較 IIS5、IIS6、IIS7 這三代 IIS 對請求的處理過程, 讓我們熟悉 ASP.NET的底層機(jī)制 并對請求(request)是怎么從Web服務(wù)器傳送到ASP.NET運(yùn)行時有所了解。通過對底層機(jī)制的了解,可以讓我們對 ASP.net 有更深的理解。
IIS 5 的 ASP.net 請求處理過程

對圖的解釋:
IIS 5.x 一個顯著的特征就是 Web Server 和真正的 ASP.NET Application 的分離。作為 Web Server 的IIS運(yùn)行在一個名為 InetInfo.exe 的進(jìn)程上,InetInfo.exe 是一個Native Executive,并不是一個托管的程序,而我們真正的 ASP.NET Application 則是運(yùn)行在一個叫做 aspnet_wp 的 Worker Process 上面,在該進(jìn)程初始化的時候會加載CLR,所以這是一個托管的環(huán)境。
ISAPI: 指能夠處理各種后綴名的應(yīng)用程序。 ISAPI 是下面單詞的簡寫 :Internet Server Application Programe Interface,互聯(lián)網(wǎng)服務(wù)器應(yīng)用程序接口。
IIS 5 模式的特點:
- 首先,同一臺主機(jī)上在同一時間只能運(yùn)行一個 aspnet_wp 進(jìn)程,每個基于虛擬目錄的 ASP.NET Application 對應(yīng)一個 Application Domain ,也就是說每個 Application 都運(yùn)行在同一個 Worker Process 中,Application之間的隔離是基于 Application Domain 的,而不是基于Process的。
- 其次,ASP.NET ISAPI 不但負(fù)責(zé)創(chuàng)建 aspnet_wp Worker Process,而且負(fù)責(zé)監(jiān)控該進(jìn)程,如果檢測到 aspnet_wp 的 Performance 降低到某個設(shè)定的下限,ASP.NET ISAPI 會負(fù)責(zé)結(jié)束掉該進(jìn)程。當(dāng) aspnet_wp 結(jié)束掉之后,后續(xù)的 Request 會導(dǎo)致ASP.NET ISAPI 重新創(chuàng)建新的 aspnet_wp Worker Process。
- 最后,由于 IIS 和 Application 運(yùn)行在他們各自的進(jìn)程中,他們之間的通信必須采用特定的通信機(jī)制。本質(zhì)上 IIS 所在的 InetInfo 進(jìn)程和 Worker Process 之間的通信是同一臺機(jī)器不同進(jìn)程的通信(local interprocess communications),處于Performance的考慮,他們之間采用基于Named pipe的通信機(jī)制。ASP.NET ISAPI和Worker Process之間的通信通過他們之間的一組Pipe實現(xiàn)。同樣處于Performance的原因,ASP.NET ISAPI 通過異步的方式將Request 傳到Worker Process 并獲得 Response,但是 Worker Process 則是通過同步的方式向 ASP.NET ISAPI 獲得一些基于 Server 的變量。
IIS6 的 ASP.net 請求處理過程

對圖的解釋:
IIS 5.x 是通過 InetInfo.exe 監(jiān)聽 Request 并把Request分發(fā)到Work Process。換句話說,在IIS 5.x中對Request的監(jiān)聽和分發(fā)是在User Mode中進(jìn)行,在IIS 6中,這種工作被移植到kernel Mode中進(jìn)行,所有的這一切都是通過一個新的組件:http.sys 來負(fù)責(zé)。
注:為了避免用戶應(yīng)用程序訪問或者修改關(guān)鍵的操作系統(tǒng)數(shù)據(jù),windows提供了兩種處理器訪問模式:用戶模式(User Mode)和內(nèi)核模式(Kernel Mode)。一般地,用戶程序運(yùn)行在User mode下,而操作系統(tǒng)代碼運(yùn)行在Kernel Mode下。Kernel Mode的代碼允許訪問所有系統(tǒng)內(nèi)存和所有CPU指令。
在User Mode下,http.sys接收到一個基于 aspx 的http request,然后它會根據(jù)IIS中的 Metabase 查看該基于該 Request 的 Application 屬于哪個Application Pool, 如果該Application Pool不存在,則創(chuàng)建之。否則直接將 request 發(fā)到對應(yīng)Application Pool 的 Queue中。
每個 Application Pool 對應(yīng)著一個Worker Process:w3wp.exe,毫無疑問他是運(yùn)行在User Mode下的。在IIS Metabase 中維護(hù)著 Application Pool 和worker process的Mapping。WAS(Web Administrative service)根據(jù)這樣一個mapping,將存在于某個Application Pool Queue的request 傳遞到對應(yīng)的worker process(如果沒有,就創(chuàng)建這樣一個進(jìn)程)。在 worker process 初始化的時候,加載ASP.NET ISAPI,ASP.NET ISAPI 進(jìn)而加載CLR。最后的流程就和IIS 5.x一樣了:通過AppManagerAppDomainFactory 的 Create方法為 Application 創(chuàng)建一個Application Domain;通過 ISAPIRuntime 的 ProcessRequest處理Request,進(jìn)而將流程進(jìn)入到ASP.NET Http Runtime Pipeline。
相關(guān)文章
Windows Server 2012遠(yuǎn)程默認(rèn)端口3389的修改方法
本文主要介紹了Windows Server 2012遠(yuǎn)程默認(rèn)端口3389的修改方法,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2022-04-04
Windows 系統(tǒng)下安裝 IntelliJ IDEA 的方法(圖解)
本文通過圖文并茂的形式給大家介紹了Windows 系統(tǒng)下安裝 IntelliJ IDEA 的方法,文中還給大家提到了IntelliJ IDEA 注冊碼,非常不錯,具有參考借鑒價值,需要的朋友參考下2018-01-01
Windows Server 2016 PHP運(yùn)行環(huán)境安裝配置
這篇文章主要介紹了Windows Server 2016 PHP運(yùn)行環(huán)境安裝配置,需要的朋友可以參考下2017-08-08
IIS7.5 偽靜態(tài) 腳本映射 配置方法(圖文詳解)
這篇文章主要介紹了IIS7.5 偽靜態(tài) 腳本映射 配置方法,需要的朋友可以參考下2015-09-09
“/”應(yīng)用程序中的服務(wù)器錯誤和Server Error in ''''/'''' Application.的終極解決方法
“/”應(yīng)用程序中的服務(wù)器錯誤。 運(yùn)行時錯誤 說明: 服務(wù)器上出現(xiàn)應(yīng)用程序錯誤。2011-06-06
Windows Server 2008 架設(shè) Web 服務(wù)器教程(圖文詳解)
雖然 Windows Server 2008 內(nèi)置了I IS 7.0,但是默認(rèn)情況下并沒有安裝。由于 Windows Server 2008 中安裝 IIS 服務(wù)和以前操作相比有很大的不同,因此首先要首先需要參照下述步驟安裝 IIS 7.0 組件2015-07-07
記一次網(wǎng)站無法訪問解決過程,服務(wù)器80端口問題解決過程
這篇文章主要介紹了記一次網(wǎng)站無法訪問解決過程,服務(wù)器80端口問題解決過程,需要的朋友可以參考下2017-04-04

