IIS 5 與IIS 6 原理介紹

[ 轉]

ASP.NET Process Model之一:IIS 和 ASP.NET ISAPI

前幾天有一個朋友在MSN上問我“ASP.NET 從最初的接收到Http request到最終生成Response的整個流程到底是怎樣的?”我覺得這個問題涉及到IISASP.NETASP.NET Runtime的處理模型的問題,并不是三言兩語就能說清楚的,所以決定寫這樣一篇介紹IISASP.NET Runtime Process Model的文章,談談我對此的一個粗淺的認識,如果有什么不對的地方,希望大家及時指正。

這篇文章大體分為兩個部分,第一部分我將談談IIS的兩個不同的版本—IIS 5.x IIS 6(雖然IIS 7已經Release很長時間了,而且較之前兩個版本發生了非常大的變化,由于本人缺乏對IIS 7深入的了解,所以在這里就不再介紹了,不過以后我將這方面的內容補上)的處理模型:IIS如何監聽來自外界的Http request,如何根據ISAPI Extension Mapping將對于不同Resource的請求分發給不同的ISAPI Extension,基于ASP.NET ResourceASP.NET ISAPI如何將Request傳遞給ASP.NET Runtime 環境。第二部分將著重介紹在一個托管的ASP.NET Runtime 環境對傳入的Http request的處理過程。我們先來看看IIS 5.xIIS 6的處理過程。

1.???????????? 一、IIS 5.x based Process Model

IIS 5.x一個顯著的特征就是Web Server和真正的ASP.NET Application的分離。作為Web ServerIIS運行在一個名為InetInfo.exe的進程上,InetInfo.exe是一個Native Executive,并不是一個托管的程序,而我們真正的ASP.NET Application則是運行在一個叫做aspnet_wpWorker Process上面,在該進程初始化的時候會加載CLR,所以這是一個托管的環境。我們接下來將談論aspnet_wp如何創建,aspnet_wpInetInfo.exe如何進行通信,以及簡單介紹在aspnet_wp中,如何將Request 導入ASP.NET Rutime Pipeline

我們通過創建虛擬目錄將資源HostIIS下,原則上,我們可以通過IIS訪問置于虛擬目錄下的所有Resource,這部僅僅包含一些靜態資源文件,比如圖片、純Html文件、CSSJS等等,也包含一些需要動態執行的文件,比如aspxasmx等等,我們還可以將RemotingWCF Service HostIIS下。對于這些靜態的文件,IIS直接提取對應的文件將其作為Http Response返回給Client,但是對于這些需要進一步處理的動態執行的文件,IIS必須將Request進一步傳遞給對應的處理程序,待處理程序執行完畢獲得最終的Http Response通過IIS返回給Client。對于IIS來說,這些處理程序通過ISAPI Extension來體現。對于基于ASP.NETResource,其對應的ISAPI ExtensionASP.NET ISAPI,通過一個aspnet_isapi.dll承載。IISMetadata database維護著一個稱為ISAPI Extension Mapping的數據表,負責將不同類型的Resource影射到對應的ISAPI Extension


上圖像我們展示了
IIS 5.x如何處理一個基于ASP.NET Resource(以aspx為例)的Http Request的大體流程。首先用戶通過Browser請求一個aspx pageBrower向對于得Web Server,也就是目標主機的IIS。在上面我們提到過,IIS運行在一個稱為InetInfo.exe的進程中,InetInfo.exe是一個Native Executive,并非一個托管的程序。IIS分析Request的目標資源文件的擴展名(這里是aspx),通過ISAPI Extension Mapping獲知對應的ISPAIASP.NET ISAPI,于是加載aspnet_isapi.dll。到此為止,該Request的處理交由ASP.NET ISAPI,處理。ASP.NET ISAPI會創建一個叫做aspnet_wp.exeWorker Process(如果該進程不存在的話),在aspnet_wp.exe初始化的時候會加載CLR,從而為ASP.NET Application創建一個托管的運行環境,在CLR初始化的使用會加載兩個重要的dllAppManagerAppDomainFactoryISAPIRuntime。通過AppManagerAppDomainFactoryCreate方法為Application創建一個Application Domain;通過ISAPIRuntimeProcessRequest處理Request,進而將流程拖入到ASP.NET Http Runtime Pipeline的范疇,ASP.NET Http Runtime PipelineHttp Request的處理是一個相對復雜的過程,相關的介紹會放在本篇文章的下一部份。在這里我們可以把它看成是一個黑盒,它接管Request,最終生成Html

這基本上就是整個處理流程,很簡單。不過在這里有幾點需要特別指出的。

1. 首先,同一臺主機上再同一時間只能運行一個aspnet_wp進程,每個基于虛擬目錄的ASP.NET Application對應一個Application Domain,也就是說每個Application都運行在同一個Worker Process中,Application之間的隔離是基于Application Domain的,而不是基于Process的。

2. 其次,ASP.NET? ISAPI不但負責創建aspnet_wp Worker Process,而且負責監控該進程,如果檢測到aspnet_wpPerformance降低到某個設定的下限,ASP.NET? ISAPI會負責結束掉該進程。當aspnet_wp結束掉之后,后續的Request會導致ASP.NET ISAPI重新創建新的aspnet_wp Worker Process

3. 最后,由于IISApplication運行在他們各自的進程中,他們之間的通信必須采用特定的通信機制。本質上IIS所在的InetInfo進程和Worker Process之間的通信是同一臺機器不同進程的通信(local interprocess communications),處于Performance的考慮,他們之間采用基于Named pipe的通信機制。ASP.NET ISAPIWorker Process之間的通信通過他們之間的一組Pipe實現。同樣處于Performance的原因,ASP.NET ISAPI通過異步的方式將Request 傳到Worker Process并獲得Response,但是Worker Process則是通過同步的方式向ASP.NET ISAPI獲得一些基于Server的變量。

2.???????????? 二、IIS 6 based Process Model

Reliability Performance永遠是我們從事軟件開發不變的主題。作為Host 基于Http ApplicationIIS來說,這兩方面就顯得尤為重要了。我們從IIS 5.xIIS 6 的演變,不難看出IIS 6在前一個版本基礎上所作的改進也是基于這兩個方面。在介紹IIS 6的處理模型之前,我們先看看IIS 5.x都什么樣缺陷:

1. 首先從Performance上看,IISapplication運行在不同的進程中,雖然他們之間采用了基于Named Pipe的異步通信方式,但是一個基于進程之間的通信對性能的影響確實不能從根本上解決。

2. 其次,從Reliability來考慮,一臺機器上只能運行一個worker process,每個Application運行在同一個進程中,雖然基于Application Domain的隔離能提供一定的Reliability,但是一旦真個進程崩潰,所有的Application都受影響。所以我們有時候需要提供一個基于Process的隔離性。

基于Reliability的改進,IIS 6引入了Application Pool。顧名思義,Application Pool就是一個application的容器,在IIS 6中,我們可以創建若干Application Pool,在創建Web Application的時候,我們為它指定一個既定的application pool。在運行的時候,一個Application pool對應一個Worker Processw3wp.exe。也就是說,和前一個版本的IIS不同的是,對于IIS 6來說,同一臺機器上可以同時運行多個Worker Process,每個Worker Process中的每個Application domain對應一個Application。這樣,Application之間不但能提供Application Domain級別的隔離,你也可以將不同的Application置于不同的Application Pool中,從而基于Process級別的隔離。對于Host 一些重要的Application來說,這樣的方式可以提供很好的Reliability

Performance方面,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 ModeKernel Mode以及一些Windows底層的一些內容,推薦大家看看《Microsoft Windows InternalFour Edition Authored by Mark E.Russinovich & David A. Solomon


上圖基本上演示了
IIS 6整個處理過程。在Kernel Mode下,http.sys接收到一個基于aspxhttp request,然后它會根據IIS中的Metabase查看該基于該RequestApplication屬于哪個Application Pool,如果該Application Pool不存在,則創建之。否則直接將request發到對應Application PoolQueue中。我上面已經說了,每個Application Pool對應著一個Worker Processw3wp.exe,毫無疑問他是運行在User Mode下的。在IIS Metabase中維護著Application Poolworker processMappingWASWeb Administrative service)根據這樣一個mapping,將存在于某個Application Pool Queuerequest 傳遞到對應的worker process(如果沒有,就創建這樣一個進程)。在worker process初始化的時候,加載ASP.NET ISAPIASP.NET ISAPI進而加載CLR。最后的流程就和IIS 5.x一樣了:通過AppManagerAppDomainFactoryCreate方法為Application創建一個Application Domain;通過ISAPIRuntimeProcessRequest處理Request,進而將流程進入到ASP.NET Http Runtime Pipeline

IIS Process Model部分就介紹到這里,在下部分中,我將介紹ASP.NET Http Runtime Pipeline
Reference:

The ASP.NET HTTP Runtime

ASP.NET Internals – IIS and the Process Model

ASP.NET Internals - The bridge between ISAPI and Application Domains

Microsoft? Windows? Internals, Fourth Edition: Microsoft Windows Server? 2003, Windows XP, and Windows 2000

轉載于:https://www.cnblogs.com/jenneyblog/archive/2013/03/13/IIS5_and_IIS6_ProcessModel.html

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/536351.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/536351.shtml
英文地址,請注明出處:http://en.pswp.cn/news/536351.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

UVA340????????Master-Mind Hints【數組】

Master-Mind Hints UVA - 340 題目傳送門 題目大意:先輸入一個整數n,表示有n個數字,下面第一行代表正確答案,其下每一行代表用戶猜的答案,需統計其有多少數字位置正確(A),有多少數…

教你如何把自己從好友的QQ中刪除

在QQ中,有些人看了不太順眼,真不知當初為何讓他加自己為好友的! 那有什么辦法,可以把自己從對方的QQ中刪除呢? 其實,用QQ就可以輕松搞定! 讓我來為你支一招吧! 打開QQ&#xff0…

UVA1583?Digit Generator

Digit Generator UVA - 1583 題目傳送門 題目大意&#xff1a;若x的各位數之和加上x本身等于y&#xff0c;則證明x是y的生成元&#xff0c;求輸入數字n的最小生成元。 AC代碼&#xff1a; #include <cstdio> #include <iostream> #include <algorithm> …

C++內存詳解

偉大的Bill Gates 曾經失言&#xff1a; 640K ought to be enough for everybody — Bill Gates 1981 程序員們經常編寫內存管理程序&#xff0c;往往提心吊膽。如果不想觸雷&#xff0c;唯一的解決辦法就是發現所有潛伏的地雷并且排除它們&#xff0c;躲是躲不了的。本文的內…

UVA1584????????Circular Sequence【字符串】

Circular Sequence UVA - 1584 題目傳送門 題目大意&#xff1a;輸入一個環形字符串&#xff0c;需輸出其最小字典序的形式的字符串。 AC代碼&#xff1a; #include <cstdio> #include <iostream> #include <algorithm> #include <cmath> #includ…

UVA1585 Score

Score UVA - 1585 題目傳送門 題目大意&#xff1a;輸入一個字符串&#xff0c;O的分數為1&#xff0c;若出現連續的O&#xff0c;如OOOO...&#xff0c;分數為1,2,3,4...&#xff0c;X為0分&#xff0c;求最終的分數 AC代碼&#xff1a; #include <cstdio> #includ…

operater int()

class Number { int number; public: explicit Number(int n){number n;} operator int() //注意一定不能聲明返回值 { return number; } }; int main () { Number n1 Number(100); int n2 n1; cout << n2 << endl; re…

UVA1586???????? Molar mass

Molar mass UVA - 1586 題目傳送門 題目大意&#xff1a;給你一個只包含C,H,O,N分子式&#xff0c;其中C,H,O,N的原子量分別為&#xff1a;12.01,1.008,16.00,14.01&#xff0c;求其分子量 AC代碼&#xff1a; #include <cstdio> #include <iostream> #includ…

SharePoint v3:忘掉模擬用戶Impersonate,SPSecurity.RunWithElevatedPrivileges來了

回顧&#xff1a; 在SharePoint V2 大家應該都用過模擬用戶Impersonate這個功能&#xff0c; 這個功能用來暫時提升某個用戶的權限&#xff0c;比如某個普通用戶的本來不能修改某個列表的值&#xff0c;但是我們功能需要在修改。 缺點&#xff1a; 我們使用這個模擬用戶功能…

UVA1225????????Digit Counting

Digit Counting UVA - 1225 題目傳送門 題目大意&#xff1a;輸入一個數字T&#xff0c;代表有T組測試數據&#xff0c;下面每行有一個整數n&#xff0c;求將1到n的數字連成一串后每個數字出現的個數。 AC代碼&#xff1a; #include <cstdio> #include <iostream&…

Chess Queen【數學】

Chess Queen UVA - 11538 題目傳送門 題目大意&#xff1a;輸入兩個整數n,m&#xff0c;在n行m列的棋盤中放入白黑兩個棋子&#xff0c;棋子在同一行、同一列或同一對角線上能相互進攻&#xff0c;問有多少種擺放方案。 AC代碼&#xff1a; #include <cstdio> #incl…

Java開發中保證接口的冪等性問題

目錄 1、解決方案 2、使用token保證接口冪等性的例子 3、在實際項目中&#xff0c;如何有效地使用token法來保證接口的冪等性&#xff1f; 4、3示例中如何獲取請求中的 token 5、如果token驗證失敗&#xff0c;如何處理 6、在上述示例代碼中加上token過期后重置的功能 7…

typedef 的四個用途和兩大陷阱

>>>>>用途一&#xff1a;定義一種類型的別名&#xff0c;而不只是簡單的宏替換。可以用作同時聲明指針型的多個對象。比如&#xff1a;char* pa, pb; // 這多數不符合我們的意圖&#xff0c;它只聲明了一個指向字符變量的指針&#xff0c; // 和一個字符變量&am…

Triangle Counting【數學】

Triangle Counting UVA - 11401 題目傳送門 題目大意&#xff1a;輸入一個整數n&#xff0c;求在1到n中選取三條邊能夠組成多少種三角形。 AC代碼&#xff1a; #include <cstdio> #include <iostream> #include <algorithm> #include <cmath> #in…

Cheerleaders【容斥】

Cheerleaders UVA - 11806 題目傳送門 題目大意&#xff1a;給你三個整數n,m,k&#xff0c;代表有一個n行m列的場地&#xff0c;共有k個人&#xff0c;需保證在最外圍的一圈的每行每列都必須要有一個人&#xff0c;若這個人在對角上&#xff0c;則可以當做他所在的行列都已經…

Exploring Pyramids【動態規劃——區間DP】

Exploring Pyramids UVALive - 3516 題目傳送門 題目大意&#xff1a;給你一個字符串&#xff0c;其代表的是機器人來回走過的路徑&#xff0c;機器人總是先走左邊再走右邊&#xff0c;問有多少種情況。 解決方法&#xff1a;設輸入序列為S&#xff0c;d(i,j)為子序列Si,Si…

Investigating Div-Sum Property【數位DP】

Investigating Div-Sum Property UVA - 11361 題目傳送門 題目大意&#xff1a;輸入三個數a,b,k&#xff0c;問從a到b中有多少個數滿足數字能夠整除k&#xff0c;并且其數位和也能整除k。 解決方法&#xff1a;數位DP的模板題&#xff0c;Dp[x]表示在不超過x的數中滿足條件…

UVA - 455?Periodic Strings【字符串】

Periodic Strings UVA - 455 題目傳送門 題目大意&#xff1a;先輸入一個數字n&#xff0c;在輸入n行字符串&#xff0c;對每一個字符串輸出其最小的周期長度&#xff0c;每兩個輸出間有一空行。 AC代碼&#xff1a; #include <cstdio> #include <iostream> #…

螺旋方陣問題【數組】

輸入n&#xff0c;輸出n階螺旋方陣&#xff0c;下面為5階螺旋方陣&#xff1a;1 2 3 4 5 16 17 18 19 6 15 24 25 20 7 14 23 22 21 8 13 12 11 10 9 下面為我的代碼&#xff1a; #include <cstdio> #include <iostream> #include &…

馬鞍點問題【數組】

如果在一矩陣中元素A[i][j]滿足A[i][j]為第i行的最小值&#xff0c;第j行的最大值&#xff0c;則稱這個元素為這個矩陣的馬鞍點&#xff0c;求m*n矩陣所有的馬鞍點。若需求一個矩陣的所有馬鞍點&#xff0c;其實只需將矩陣的每行的最小值與每列的最大值分別求出存在相應的數組中…