絕大多數(shù)的人只熟悉高層的框架如: WebForms 和 WebServices --這些都在ASP.NET層次結(jié)構(gòu)在最高層。
這篇文章的資料收集整理自各種微軟公開(kāi)的文檔,通過(guò)比較 IIS5、IIS6、IIS7 這三代 IIS 對(duì)請(qǐng)求的處理過(guò)程, 讓我們熟悉 ASP.NET的底層機(jī)制 并對(duì)請(qǐng)求(request)是怎么從Web服務(wù)器傳送到ASP.NET運(yùn)行時(shí)有所了解。通過(guò)對(duì)底層機(jī)制的了解,可以讓我們對(duì) ASP.net 有更深的理解。
IIS 5 的 ASP.net 請(qǐng)求處理過(guò)程
對(duì)圖的解釋?zhuān)?/P>
IIS 5.x 一個(gè)顯著的特征就是 Web Server 和真正的 ASP.NET Application 的分離。作為 Web Server 的IIS運(yùn)行在一個(gè)名為 InetInfo.exe 的進(jìn)程上,InetInfo.exe 是一個(gè)Native Executive,并不是一個(gè)托管的程序,而我們真正的 ASP.NET Application 則是運(yùn)行在一個(gè)叫做 aspnet_wp 的 Worker Process 上面,在該進(jìn)程初始化的時(shí)候會(huì)加載CLR,所以這是一個(gè)托管的環(huán)境。
ISAPI: 指能夠處理各種后綴名的應(yīng)用程序。 ISAPI 是下面單詞的簡(jiǎn)寫(xiě) :Internet Server Application Programe Interface,互聯(lián)網(wǎng)服務(wù)器應(yīng)用程序接口。
IIS 5 模式的特點(diǎn):
IIS6 的 ASP.net 請(qǐng)求處理過(guò)程
對(duì)圖的解釋?zhuān)?/P>
IIS 5.x 是通過(guò) InetInfo.exe 監(jiān)聽(tīng) Request 并把Request分發(fā)到Work Process。換句話說(shuō),在IIS 5.x中對(duì)Request的監(jiān)聽(tīng)和分發(fā)是在User Mode中進(jìn)行,在IIS 6中,這種工作被移植到kernel Mode中進(jìn)行,所有的這一切都是通過(guò)一個(gè)新的組件:http.sys 來(lái)負(fù)責(zé)。
注:為了避免用戶(hù)應(yīng)用程序訪問(wèn)或者修改關(guān)鍵的操作系統(tǒng)數(shù)據(jù),windows提供了兩種處理器訪問(wèn)模式:用戶(hù)模式(User Mode)和內(nèi)核模式(Kernel Mode)。一般地,用戶(hù)程序運(yùn)行在User mode下,而操作系統(tǒng)代碼運(yùn)行在Kernel Mode下。Kernel Mode的代碼允許訪問(wèn)所有系統(tǒng)內(nèi)存和所有CPU指令。
在User Mode下,http.sys接收到一個(gè)基于 aspx 的http request,然后它會(huì)根據(jù)IIS中的 Metabase 查看該基于該 Request 的 Application 屬于哪個(gè)Application Pool, 如果該Application Pool不存在,則創(chuàng)建之。否則直接將 request 發(fā)到對(duì)應(yīng)Application Pool 的 Queue中。
每個(gè) Application Pool 對(duì)應(yīng)著一個(gè)Worker Process:w3wp.exe,毫無(wú)疑問(wèn)他是運(yùn)行在User Mode下的。在IIS Metabase 中維護(hù)著 Application Pool 和worker process的Mapping。WAS(Web Administrative service)根據(jù)這樣一個(gè)mapping,將存在于某個(gè)Application Pool Queue的request 傳遞到對(duì)應(yīng)的worker process(如果沒(méi)有,就創(chuàng)建這樣一個(gè)進(jìn)程)。在 worker process 初始化的時(shí)候,加載ASP.NET ISAPI,ASP.NET ISAPI 進(jìn)而加載CLR。最后的流程就和IIS 5.x一樣了:通過(guò)AppManagerAppDomainFactory 的 Create方法為 Application 創(chuàng)建一個(gè)Application Domain;通過(guò) ISAPIRuntime 的 ProcessRequest處理Request,進(jìn)而將流程進(jìn)入到ASP.NET Http Runtime Pipeline。
新聞熱點(diǎn)
疑難解答
圖片精選