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

來源:互聯網
上載者:User

一、IIS 5.x based Process Model

  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,所以這是一個託管的環境。我們接下來將談論aspnet_wp如何建立,aspnet_wp和InetInfo.exe如何進行通訊,以及簡單介紹在aspnet_wp中,如何將Request 匯入ASP.NET Rutime Pipeline。

  我們通過建立虛擬目錄將資源Host到IIS下,原則上,我們可以通過IIS訪問置於虛擬目錄下的所有Resource,這部僅僅包含一些靜態資源檔案,比片、純Html檔案、CSS、JS等等,也包含一些需要動態執行的檔案,比如aspx,asmx等等,我們還可以將Remoting和WCF Service Host到IIS下。對於這些靜態檔案,IIS直接提取對應的檔案將其作為Http Response返回給Client,但是對於這些需要進一步處理的動態執行的檔案,IIS必須將Request進一步傳遞給對應的處理常式,待處理常式執行完畢獲得最終的Http Response通過IIS返回給Client。對於IIS來說,這些處理常式通過ISAPI Extension來體現。對於基於ASP.NET的Resource,其對應的ISAPI Extension為ASP.NET ISAPI,通過一個aspnet_isapi.dll承載。IIS的Metadata database維護著一個稱為ISAPI Extension Mapping的資料表,負責將不同類型的Resource影射到對應的ISAPI Extension。

  首先使用者通過Browser請求一個aspx page,Brower向對於得Web Server,也就是目標主機的IIS。在上面我們提到過,IIS運行在一個稱為InetInfo.exe的進程中,InetInfo.exe是一個Native Executive,並非一個託管的程式。IIS分析Request的目標資源檔的副檔名(這裡是aspx),通過ISAPI Extension Mapping獲知對應的ISPAI為ASP.NET ISAPI,於是載入aspnet_isapi.dll。到此為止,該Request的處理交由ASP.NET ISAPI,處理。ASP.NET ISAPI會建立一個叫做aspnet_wp.exe的Worker Process(如果該進程不存在的話),在aspnet_wp.exe初始化的時候會載入CLR,從而為ASP.NET Application建立一個託管的運行環境,在CLR初始化的使用會載入兩個重要的dll:AppManagerAppDomainFactory和ISAPIRuntime。通過AppManagerAppDomainFactory的Create方法為Application建立一個Application Domain;通過ISAPIRuntime的ProcessRequest處理Request,進而將流程拖入到ASP.NET Http Runtime Pipeline的範疇,ASP.NET Http Runtime Pipeline對Http 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_wp的Performance降低到某個設定的下限,ASP.NET ISAPI會負責結束掉該進程。當aspnet_wp結束掉之後,後續的Request會導致ASP.NET ISAPI重新建立新的aspnet_wp Worker Process。

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

二、IIS 6 based Process Model

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

  1. 首先從Performance上看,IIS和application運行在不同的進程中,雖然他們之間採用了基於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對應一個Worker Process:w3wp.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 Mode和Kernel Mode以及一些Windows底層的一些內容,推薦大家看看《Microsoft Windows Internal》Four Edition, Authored by Mark E.Russinovich & David A. Solomon。

  在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。

 

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.