各版本IIS下ASP.net請(qǐng)求處理過(guò)程區(qū)別第1/3頁(yè)
這篇文章的資料收集整理自各種微軟公開(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ì)圖的解釋:
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)寫 :Internet Server Application Programe Interface,互聯(lián)網(wǎng)服務(wù)器應(yīng)用程序接口。
IIS 5 模式的特點(diǎn):
- 首先,同一臺(tái)主機(jī)上在同一時(shí)間只能運(yùn)行一個(gè) aspnet_wp 進(jìn)程,每個(gè)基于虛擬目錄的 ASP.NET Application 對(duì)應(yīng)一個(gè) Application Domain ,也就是說(shuō)每個(gè) Application 都運(yùn)行在同一個(gè) Worker Process 中,Application之間的隔離是基于 Application Domain 的,而不是基于Process的。
- 其次,ASP.NET ISAPI 不但負(fù)責(zé)創(chuàng)建 aspnet_wp Worker Process,而且負(fù)責(zé)監(jiān)控該進(jìn)程,如果檢測(cè)到 aspnet_wp 的 Performance 降低到某個(gè)設(shè)定的下限,ASP.NET ISAPI 會(huì)負(fù)責(zé)結(jié)束掉該進(jìn)程。當(dāng) aspnet_wp 結(jié)束掉之后,后續(xù)的 Request 會(huì)導(dǎo)致ASP.NET ISAPI 重新創(chuàng)建新的 aspnet_wp Worker Process。
- 最后,由于 IIS 和 Application 運(yùn)行在他們各自的進(jìn)程中,他們之間的通信必須采用特定的通信機(jī)制。本質(zhì)上 IIS 所在的 InetInfo 進(jìn)程和 Worker Process 之間的通信是同一臺(tái)機(jī)器不同進(jìn)程的通信(local interprocess communications),處于Performance的考慮,他們之間采用基于Named pipe的通信機(jī)制。ASP.NET ISAPI和Worker Process之間的通信通過(guò)他們之間的一組Pipe實(shí)現(xiàn)。同樣處于Performance的原因,ASP.NET ISAPI 通過(guò)異步的方式將Request 傳到Worker Process 并獲得 Response,但是 Worker Process 則是通過(guò)同步的方式向 ASP.NET ISAPI 獲得一些基于 Server 的變量。
IIS6 的 ASP.net 請(qǐng)求處理過(guò)程
對(duì)圖的解釋:
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é)。
注:為了避免用戶應(yīng)用程序訪問(wèn)或者修改關(guān)鍵的操作系統(tǒng)數(shù)據(jù),windows提供了兩種處理器訪問(wèn)模式:用戶模式(User Mode)和內(nèi)核模式(Kernel Mode)。一般地,用戶程序運(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。
相關(guān)文章
2009年最新版 win2003 IIS6+PHP5+MySQL5+Zend Optimizer+phpMyAdmin安
本配置教程僅作拋磚引玉,正式生產(chǎn)用還需要對(duì)服務(wù)器進(jìn)行更加詳細(xì)的安全設(shè)置以及各方面性能調(diào)整。2009-03-03sqlserver 普通用戶運(yùn)行錯(cuò)誤解決方法補(bǔ)充
本方法作為Windows2003服務(wù)器安裝及設(shè)置教程——MSSQL安全篇一(將MS SQL SERVER運(yùn)行于普通用戶下)的補(bǔ)充,成功解決了不能將sqlserver運(yùn)行在普通用戶的權(quán)限下的問(wèn)題。2010-05-05Windows下php5+apache+mysql5 手工搭建筆記
php運(yùn)行環(huán)境對(duì)于站長(zhǎng)們或者初學(xué)者來(lái)說(shuō)可以直接用一鍵包的方式或者直接從服務(wù)提供商處得到支持,不必自己手工按部就班的搭建,所以這篇文章是寫給我這樣的菜鳥(niǎo)又喜歡胡鬧的程序員看的,哈哈。2011-02-02Winxp IIS5.1出現(xiàn)HTTP500內(nèi)部服務(wù)器錯(cuò)誤的解決方法
Winxp IIS5.1出現(xiàn)HTTP500內(nèi)部服務(wù)器錯(cuò)誤的解決方法,需要的朋友可以參考下。2011-03-03NTFS權(quán)限設(shè)置以避免通過(guò)webshell遍歷主機(jī)目錄
我們知道,匿名訪問(wèn)web使用系統(tǒng)中的“IUSR_主機(jī)名”這個(gè)用戶,只要限制了這個(gè)用戶的讀取權(quán)限,即能限制訪問(wèn)者遍歷服務(wù)器目錄,保護(hù)服務(wù)器數(shù)據(jù)不被非法訪問(wèn)2011-03-03如何備份恢復(fù)IIS?詳細(xì)備份恢復(fù)IIS的步驟
如果用戶重裝Windows的話,即使備份了IIS的相關(guān)文件,還原的時(shí)候還是提示“無(wú)效簽名”,導(dǎo)致這個(gè)IIS無(wú)法恢復(fù),如果你要重裝系統(tǒng),那么詳細(xì)備份恢復(fù)IIS的步驟如下2013-08-08serv-u與屏保導(dǎo)致serv-u服務(wù)器經(jīng)常停止無(wú)法連接的解決方法
公司win2003服務(wù)器發(fā)現(xiàn)serv-u一直以來(lái)都有經(jīng)常暫停無(wú)法連接的問(wèn)題只有重新啟動(dòng)serv-u才能解決serv-u停止問(wèn)題,還以為是版本或者流量的關(guān)系2007-12-12win2003 服務(wù)器超出最大允許連接數(shù) 最有效的解決方法
這幾天頻繁的遠(yuǎn)程登陸服務(wù)器,由于沒(méi)有及時(shí)注銷或者其他情況,早上再次登陸時(shí)系統(tǒng)提示:終端服務(wù)器超出了最大允許連接數(shù)2012-11-11iis偽靜態(tài)中文url出現(xiàn)亂碼的解決辦法
這篇文章主要介紹了iis偽靜態(tài)中文url出現(xiàn)亂碼的解決辦法,需要的朋友可以參考下2017-05-05