這篇文章大體分為兩個(gè)部分,第一部分我將談?wù)処IS的兩個(gè)不同的版本―IIS 5.x 和 IIS 6(雖然IIS 7已經(jīng)Release很長時(shí)間了,而且較之前兩個(gè)版本發(fā)生了非常大的變化,由于本人缺乏對IIS 7深入的了解,所以在這里就不再介紹了,不過以后我將這方面的內(nèi)容補(bǔ)上)的處理模型:IIS如何監(jiān)聽來自外界的Http request,如何根據(jù)ISAPI Extension Mapping將對于不同Resource的請求分發(fā)給不同的ISAPI Extension,基于ASP.NET Resource的ASP.NET ISAPI如何將Request傳遞給ASP.NET Runtime 環(huán)境。第二部分將著重介紹在一個(gè)托管的ASP.NET Runtime 環(huán)境對傳入的Http request的處理過程。我們先來看看IIS 5.x和IIS 6的處理過程。
1. 一、IIS 5.x based Process Model
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í)候會加載CLR,所以這是一個(gè)托管的環(huán)境。我們接下來將談?wù)揳spnet_wp如何創(chuàng)建,aspnet_wp和InetInfo.exe如何進(jìn)行通信,以及簡單介紹在aspnet_wp中,如何將Request 導(dǎo)入ASP.NET Rutime Pipeline。
我們通過創(chuàng)建虛擬目錄將資源Host到IIS下,原則上,我們可以通過IIS訪問置于虛擬目錄下的所有Resource,這部僅僅包含一些靜態(tài)資源文件,比如圖片、純Html文件、CSS、JS等等,也包含一些需要動態(tài)執(zhí)行的文件,比如aspx,asmx等等,我們還可以將Remoting和WCF Service Host到IIS下。對于這些靜態(tài)的文件,IIS直接提取對應(yīng)的文件將其作為Http Response返回給Client,但是對于這些需要進(jìn)一步處理的動態(tài)執(zhí)行的文件,IIS必須將Request進(jìn)一步傳遞給對應(yīng)的處理程序,待處理程序執(zhí)行完畢獲得最終的Http Response通過IIS返回給Client。對于IIS來說,這些處理程序通過ISAPI Extension來體現(xiàn)。對于基于ASP.NET的Resource,其對應(yīng)的ISAPI Extension為ASP.NET ISAPI,通過一個(gè)aspnet_isapi.dll承載。IIS的Metadata database維護(hù)著一個(gè)稱為ISAPI Extension Mapping的數(shù)據(jù)表,負(fù)責(zé)將不同類型的Resource影射到對應(yīng)的ISAPI Extension。
上圖像我們展示了IIS 5.x如何處理一個(gè)基于ASP.NET Resource(以aspx為例)的Http Request的大體流程。首先用戶通過Browser請求一個(gè)aspx page,Brower向?qū)τ诘肳eb Server,也就是目標(biāo)主機(jī)的IIS。在上面我們提到過,IIS運(yùn)行在一個(gè)稱為InetInfo.exe的進(jìn)程中,InetInfo.exe是一個(gè)Native Executive,并非一個(gè)托管的程序。IIS分析Request的目標(biāo)資源文件的擴(kuò)展名(這里是aspx),通過ISAPI Extension Mapping獲知對應(yīng)的ISPAI為ASP.NET ISAPI,于是加載aspnet_isapi.dll。到此為止,該Request的處理交由ASP.NET ISAPI,處理。ASP.NET ISAPI會創(chuàng)建一個(gè)叫做aspnet_wp.exe的Worker Process(如果該進(jìn)程不存在的話),在aspnet_wp.exe初始化的時(shí)候會加載CLR,從而為ASP.NET Application創(chuàng)建一個(gè)托管的運(yùn)行環(huán)境,在CLR初始化的使用會加載兩個(gè)重要的dll:AppManagerAppDomainFactory和ISAPIRuntime。通過AppManagerAppDomainFactory的Create方法為Application創(chuàng)建一個(gè)Application Domain;通過ISAPIRuntime的ProcessRequest處理Request,進(jìn)而將流程拖入到ASP.NET Http Runtime Pipeline的范疇,ASP.NET Http Runtime Pipeline對Http Request的處理是一個(gè)相對復(fù)雜的過程,相關(guān)的介紹會放在本篇文章的下一部份。在這里我們可以把它看成是一個(gè)黑盒,它接管Request,最終生成Html。
新聞熱點(diǎn)
疑難解答
圖片精選