亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 網站 > IIS > 正文

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

2024-08-29 03:16:08
字體:
來源:轉載
供稿:網友
前幾天有一個朋友在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文件、CSS、JS等等,也包含一些需要動態執行的文件,比如aspx,asmx等等,我們還可以將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。

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



上圖像我們展示了
IIS 5.x如何處理一個基于ASP.NET Resource(以aspx為例)的Http Request的大體流程。首先用戶通過Browser請求一個aspx page,Brower向對于得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對應一個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。

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



上圖基本上演示了IIS 6整個處理過程。在User 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 processMapping。WASWeb 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

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
久久国产精品99国产精| 九九热这里只有精品免费看| 国产福利精品视频| 国产日韩欧美电影在线观看| 国产视频在线观看一区二区| 日韩av日韩在线观看| 国产91精品久久久久久| 亚洲精品福利视频| 欧美日韩国产91| 亚洲在线免费看| 亚洲久久久久久久久久久| 国产精品第一第二| 久久青草精品视频免费观看| 91精品国产91久久久| 亚洲视频在线观看免费| 日韩av在线免费播放| 亚洲精品免费一区二区三区| 精品自拍视频在线观看| 成人免费视频xnxx.com| 久久这里有精品视频| 91av视频在线播放| 亚洲精品aⅴ中文字幕乱码| 日韩精品极品视频免费观看| 日本a级片电影一区二区| 国产a∨精品一区二区三区不卡| 亚洲精品福利免费在线观看| 欧美日韩国产一区二区三区| 精品人伦一区二区三区蜜桃免费| 日韩精品在线第一页| 69av视频在线播放| 欧美日韩激情视频| www高清在线视频日韩欧美| 国产在线观看不卡| 九九视频这里只有精品| 欧美高清无遮挡| 5252色成人免费视频| 欧美福利在线观看| 国产精品久久久久久影视| 国产高清视频一区三区| 欧美电影免费播放| 亚洲成人激情小说| 亚洲欧美中文在线视频| 青草青草久热精品视频在线网站| 亚洲深夜福利视频| 欧美午夜精品久久久久久人妖| 欧美一区深夜视频| 欧美激情综合亚洲一二区| 欧美激情中文字幕乱码免费| 欧美中文字幕视频| 91极品女神在线| 精品成人在线视频| 久久精品国产视频| 亚洲另类图片色| 欧美视频13p| 欧美激情xxxxx| 亚洲国产精品99久久| 亲爱的老师9免费观看全集电视剧| 97视频在线观看亚洲| 国产精品夜间视频香蕉| 国产一区二区三区在线观看视频| 欧美成人小视频| 国产日韩中文字幕在线| 久久久97精品| 中文字幕日韩有码| 国产成人福利视频| 精品精品国产国产自在线| 久久97久久97精品免视看| 日韩国产高清污视频在线观看| 国产经典一区二区| 国产欧美va欧美va香蕉在线| 亚洲精品720p| 亚洲第一区中文99精品| 日韩av毛片网| 国产一区二区黄| 国产91色在线|免| www国产精品视频| 国产日韩欧美一二三区| 欧美在线性视频| 深夜福利91大全| 成人综合网网址| 懂色av影视一区二区三区| 亚洲第一免费播放区| 亲爱的老师9免费观看全集电视剧| 久久久久亚洲精品| 91精品国产成人www| 亚洲女人天堂色在线7777| 国产亚洲一区精品| 91免费人成网站在线观看18| 欧美在线亚洲一区| 日韩在线不卡视频| 92国产精品久久久久首页| 97国产精品人人爽人人做| 成人欧美一区二区三区在线| 精品亚洲一区二区| 性欧美长视频免费观看不卡| 国产精品美女主播| 亚洲最大激情中文字幕| 91在线网站视频| 国产免费成人av| 国产精品中文字幕久久久| 91tv亚洲精品香蕉国产一区7ujn| 91精品久久久久久久| 日日噜噜噜夜夜爽亚洲精品| 亚洲欧美中文字幕在线一区| 日韩视频免费在线| 日韩精品极品在线观看| 精品国产自在精品国产浪潮| 亚洲最大中文字幕| 国内揄拍国内精品少妇国语| 性色av一区二区三区红粉影视| 国产精品综合网站| 久久影院资源站| 国产区精品在线观看| 国产91精品久久久久| 国产福利视频一区二区| 久久福利视频导航| 国产成人黄色av| 久久亚洲综合国产精品99麻豆精品福利| 亚洲人成人99网站| 国产欧美va欧美va香蕉在线| 2024亚洲男人天堂| 国产一区二区三区日韩欧美| 亚洲色图激情小说| 97热精品视频官网| 国产欧美精品一区二区三区-老狼| 亚洲欧美日本另类| 欧美丝袜第一区| 久久精品亚洲精品| 在线视频亚洲欧美| 日韩av中文字幕在线播放| 国产精品青青在线观看爽香蕉| 97视频在线观看视频免费视频| 亚洲精品网站在线播放gif| 欧美一级大胆视频| 久久精品久久久久| 欧美电影在线播放| 亚洲午夜女主播在线直播| 亚洲免费小视频| 91精品国产99久久久久久| 欧美多人乱p欧美4p久久| 一区二区三区动漫| 97国产真实伦对白精彩视频8| 懂色aⅴ精品一区二区三区蜜月| 欧美中文在线观看| 国产欧美一区二区三区在线看| 成人免费观看49www在线观看| 成人国内精品久久久久一区| 久久精品99久久久香蕉| 日韩电影大片中文字幕| 久久人人爽人人爽人人片av高请| 亚洲成**性毛茸茸| 91产国在线观看动作片喷水| 97欧美精品一区二区三区| 久久精品视频导航| 亚洲国产精品电影在线观看| 国产精品中文字幕在线观看| 欧美日韩ab片| 午夜精品一区二区三区在线| 26uuu久久噜噜噜噜| 亚洲免费伊人电影在线观看av| 色婷婷亚洲mv天堂mv在影片| 久久亚洲精品毛片| 懂色av中文一区二区三区天美| 色妞在线综合亚洲欧美|