麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

首頁 > 網站 > IIS > 正文

各版本IIS下ASP.net請求處理過程區別第1/3頁

2024-08-29 03:16:08
字體:
來源:轉載
供稿:網友
絕大多數的人只熟悉高層的框架如: WebForms 和 WebServices --這些都在ASP.NET層次結構在最高層。

這篇文章的資料收集整理自各種微軟公開的文檔,通過比較 IIS5、IIS6、IIS7 這三代 IIS 對請求的處理過程, 讓我們熟悉 ASP.NET的底層機制 并對請求(request)是怎么從Web服務器傳送到ASP.NET運行時有所了解。通過對底層機制的了解,可以讓我們對 ASP.net 有更深的理解。

IIS 5 的 ASP.net 請求處理過程

各版本IIS下ASP.net請求處理過程區別第1/3頁

對圖的解釋:

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,所以這是一個托管的環境。

ISAPI:  指能夠處理各種后綴名的應用程序。 ISAPI 是下面單詞的簡寫 :Internet Server Application Programe Interface,互聯網服務器應用程序接口。

IIS 5 模式的特點:

  • 首先,同一臺主機上在同一時間只能運行一個 aspnet_wp 進程,每個基于虛擬目錄的 ASP.NET Application 對應一個 Application Domain ,也就是說每個 Application 都運行在同一個 Worker Process 中,Application之間的隔離是基于 Application Domain 的,而不是基于Process的。
  • 其次,ASP.NET  ISAPI 不但負責創建 aspnet_wp Worker Process,而且負責監控該進程,如果檢測到 aspnet_wp 的 Performance 降低到某個設定的下限,ASP.NET  ISAPI 會負責結束掉該進程。當 aspnet_wp 結束掉之后,后續的 Request 會導致ASP.NET ISAPI 重新創建新的 aspnet_wp Worker Process。
  • 最后,由于 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 的變量。
  • IIS6 的 ASP.net 請求處理過程

    各版本IIS下ASP.net請求處理過程區別第1/3頁

    對圖的解釋:

    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下,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。

    發表評論 共有條評論
    用戶名: 密碼:
    驗證碼: 匿名發表
    主站蜘蛛池模板: 韩国十九禁高潮床戏在线观看 | 久久精品99久久久久久2456 | 国产精品美女久久久久久网站 | 久久经典国产视频 | 一级毛片手机在线观看 | 天天透天天狠天天爱综合97 | 国产毛片aaa一区二区三区视频 | 91成人影院| 成年免费视频黄网站在线观看 | 久久99精品国产自在现线 | 成人午夜影院 | 久久96国产精品久久秘臀 | 国产1区2区在线 | 青青草成人影视 | 国产精品免费一区二区三区四区 | 久久6国产| 亚洲乱码精品久久久久 | 成年人小视频在线观看 | 欧美成人精品欧美一级乱黄 | 神马顶级推理片免费看 | 欧美日韩亚洲精品一区二区三区 | 亚洲精品a级 | 国产精品久久久久久久四虎电影 | 色播视频在线播放 | 国产精品一区二区免费在线观看 | 91九色蝌蚪国产 | 二级大黄大片高清在线视频 | 黄片毛片一级 | 叉逼视频 | 国产精品久久久久久久久久久天堂 | 精品中文字幕久久久久四十五十骆 | 国产日韩在线观看视频 | 久久久久免费电影 | 久久成人免费观看 | 久久视频精品 | 欧美一级特黄aaaaaa在线看首页 | 超碰97最新| 55夜色66夜色国产精品视频 | www.91pron| 成人毛片网站 | 毛片国产|