11個顯著提升 ASP.NET 應用程序性能的技巧——第1部分

【編者按】本文出自站外作者 Brij Bhushan Mishra ,Brij 是微軟 MVP-ASP.NET/IIS蝎困、C# Corner MVP、CodeProject Insider,前 CodeProject MVP氏身,CodeProject Mentor 以及 CodeProject Platinum Member寒屯,擁有6年左右的高級開發(fā)工程師/架構師經(jīng)驗荐捻,自幼酷愛計算機。

采用 ASP.NET 和 IIS 構建 Web 應用程序并將其托管到 Web 服務器上極其簡單寡夹,但是許多可提升 Web 應用程序性能的機會或隱藏配置同樣不能忽視处面。本系列博文將介紹一些簡單但卻可以應用于任何 Web 應用程序的技巧,而它們卻是經(jīng)常被忽略或遺忘的菩掏。

1- 內(nèi)核模式緩存——這是廣泛用于程序編寫的主要工具之一魂角,可加速 Web 應用程序。但是大多數(shù)時候智绸,很少開發(fā)者以最佳方式應用內(nèi)核模式緩存野揪,僅僅發(fā)揮其部分主要優(yōu)勢访忿。由于所有 ASP.NET 請求均會經(jīng)歷不同階段,因此可在不同級別使用緩存斯稳,具體如下所示海铆。

11個顯著提升 ASP.NET 應用程序性能的技巧——第1部分

由上圖可見,http.sys 首先接收請求挣惰。由于 http.sys 是位于 OS 內(nèi)核內(nèi)且直接接收 TCP 層請求的http listener卧斟,因此如果使用內(nèi)核級緩存可節(jié)省大多用于服務器的時間,同時可省去用于 IIS/ASP.NET Pipeline憎茂、頁面生命周期珍语、自定義代碼、數(shù)據(jù)庫等的所有時間唇辨。使用緩存的具體步驟如下:

a)轉(zhuǎn)到 IIS 并選擇網(wǎng)站廊酣。
b)點擊 IIS 部分正下方的Output Cache 圖標。
c)點擊右側面板中 Actions 下方的 Add赏枚,出現(xiàn)以下對話框:

11個顯著提升 ASP.NET 應用程序性能的技巧——第1部分

首先需要在第一個紅框內(nèi)確定緩存至內(nèi)核的文件擴展名亡驰,然后選中第二個紅框內(nèi)的復選框。第三個紅框內(nèi)為使緩存失效的三個選項饿幅,可根據(jù)具體需求進行設置凡辱。

注:內(nèi)核級緩存具有一定局限性。由于 IIS 所有功能均針對用戶級栗恩,因此無法使用任何功能透乾。不能使用內(nèi)核緩存情況的完整列表見 msdn 文章。

2- Pipeline 模式(IIS 7+可用)——應用程序池級有兩種 Pipeline 模式可用:經(jīng)典模式和集成模式磕秤。經(jīng)典模式可用于支持來自 IIS6 的應用程序乳乌。因此,首先需要了解這兩種模式市咆。IIS 許多功能均以 IIS 模塊形式實現(xiàn)汉操,同樣也有不少功能以 HTTP 模塊實現(xiàn),而 HTTP 模塊構成 ASP.NET Pipeline 的一部分蒙兰。在經(jīng)典模式下断凶,所有請求在被處理之前首先經(jīng)過 IIS Pipeline缝其,再經(jīng)過 ASP.NET Pipeline威根。許多功能同時是兩種 Pipeline 的一部分瓶竭,比如 Authentication。在集成模式下挠他,兩種 Pipeline 合而為一扳抽,所有模塊(IIS 模塊及 ASP.NET 模塊)出現(xiàn)時便從單一事件調(diào)用,從而降低冗余性且對提升應用程序性能非常有幫助。

選擇相應應用程序池并右擊屬性贸呢,便可設置/更新 Pipeline 模式赂苗。

11個顯著提升 ASP.NET 應用程序性能的技巧——第1部分

可在上圖紅框內(nèi)設置 Pipeline 模式。

注:切勿盲目更改設置贮尉。如果應用程序來自 IIS6,則可能對 IIS6 存在一定依賴性朴沿。因此猜谚,徹底更改設置后,進行測試后方可進入下一步赌渣。

3- 刪除不用的模塊——所有請求均會經(jīng)過 ASP.NET Pipeline魏铅,而 ASP.NET Pipeline 包含許多 HTTP 模塊,以及一個 http handler坚芜,如下圖所示對請求進行處理:

11個顯著提升 ASP.NET 應用程序性能的技巧——第1部分

由上圖可見览芳,請求經(jīng)過所有模塊,再經(jīng)處理程序處理鸿竖,然后再次經(jīng)過各個模塊沧竟。默認情況下,ASP.NET 應用程序究竟啟用了多少個模塊缚忧。通過添加以下代碼得到所有模塊列表:

HttpApplication httpApps = HttpContext.ApplicationInstance;

//Get list of active modules
HttpModuleCollection httpModuleCollections = httpApps.Modules;
ViewBag.ModulesCount = httpModuleCollections.Count;

得到的模塊可綁定至任何控件悟泵,具體結果如下:

11個顯著提升 ASP.NET 應用程序性能的技巧——第1部分

上圖顯示已啟用18個模塊,而其中有些模塊并未真正使用闪水,但是請求仍需通過所有模塊糕非。因此,可從 Pipeline 中刪除不用的模塊球榆。只需在 web.config 中添加下列配置便可刪除模塊:

  <system.webServer>
    <modules>
      <remove name="FormsAuthentication" />
      <remove name="DefaultAuthentication" />
      <remove name="OutputCache" />
      <remove name="AnonymousIdentification" />
      <remove name="RoleManager" />
    modules>
  system.webServer>

此處朽肥,采用刪除標記列出需要刪除的模塊。由于在此刪除了5個模塊持钉,下次查看現(xiàn)用模塊便只有13個衡招。

注:示例為2013版,如果使用其他版本右钾,得到的模塊數(shù)可能不相同蚁吝,但重點是需刪除不需要的模塊。

4- 為所有請求運行所有托管模塊——這是存在于 web.config 或 applicationHost.config中的另一配置舀射,通過以下代碼設置對IIS 上所有應用程序有效窘茁。

<modules runAllManagedModulesForAllRequests="true">

這意味著,可為到達應用程序的所有請求運行所有模塊脆烟,但由于只需運行 ASP.NET 文件而非 css山林、js、jpg、html等其他文件驼抹,因此通常不需要運行所有模塊桑孩。也就是說,即使這些資源的請求經(jīng)過 Pipeline框冀,但這些文件并不需要通過 Pipeline流椒,因為這樣只會增加額外開支,但不能僅僅在應用程序級設置為假明也。因此宣虾,可通過以下兩種方式解決:

a) 另外創(chuàng)建一個應用程序來處理上述靜態(tài)資源,并在 web.config 中將其設置為假温数。

b) 或者在同一應用程序中绣硝,將所有靜態(tài)資源放入一個文件夾,添加針對該文件夾的 web.config 文件撑刺,并將其設置為假鹉胖。

5- 切勿在文件夾 c:\inetpub\wwwroot中寫入任何內(nèi)容——文件觀察程序會查看文件夾,如果文件夾出現(xiàn)任何變更够傍,文件觀察程序便會重啟相應的應用程序池甫菠。此功能在 IIS 中可用,如果 web.config 或任何文件出現(xiàn)任何變更王带,文件觀察程序便會重啟應用程序池淑蔚,使得修改后的應用程序可處理請求。現(xiàn)在假設將應用程序日志寫入應用程序文件夾內(nèi)的文本文件內(nèi)愕撰,使得各請求均有幾個條目刹衫,從而導致應用程序池會多次重啟,這對應用程序具有危害性搞挣。因此带迟,與此相反,請勿在此文件夾內(nèi)寫入或變更任何內(nèi)容囱桨,直至此文件不再是 application binaries 的一部分仓犬。

6- 刪除多余的視圖引擎——a)眾所周知,視圖引擎是 MVC 請求生命周期的一部分舍肠,且負責發(fā)現(xiàn)并處理視圖搀继。也可添加自定義的視圖引擎。接下來創(chuàng)建默認的 MVC 應用程序并試圖返回解決方案中不存在的視圖〈溆铮現(xiàn)在運行此應用程序會出現(xiàn)以下錯誤叽躯。

11個顯著提升 ASP.NET 應用程序性能的技巧——第1部分

上圖表明應用程序在查找所有可能位置的 razor 和 aspx 文件。但是由于已知使用的是 razor 視圖引擎并且查找其他 aspx 文件并不能解決問題肌括,因此不應浪費時間查找其他 aspx 文件点骑,從而應刪除多余的視圖引擎。需要采用 Application_Start 方法添加以下代碼,Application_Start 方法在 Global.asax 內(nèi)可用黑滴。

            // Removing all the view engines
            ViewEngines.Engines.Clear();

            //Add Razor Engine (which we are using)
     ViewEngines.Engines.Add(new RazorViewEngine());

現(xiàn)在再次運行應用程序憨募。

現(xiàn)在應用程序只查找 razor 文件。

b) 仔細看以上截圖可發(fā)現(xiàn)應用程序在查找 c# 和 vb 文件袁辈,假設解決方案中從未使用 vb菜谣,因此查找 vbhtml 文件并無任何作用。欲解決這個問題晚缩,需要編寫自定義的視圖引擎葛菇。因此,按照以下方法編寫自定義 razor 視圖引擎:

    public class MyCustomViewEngine : RazorViewEngine
    {
        public MyCustomViewEngine()
        {
            base.AreaViewLocationFormats = new string[] {"~/Areas/{2}/Views/{1}/{0}.cshtml", "~/Areas/{2}/Views/Shared/{0}.cshtml"};
            base.AreaMasterLocationFormats = new string[] {"~/Areas/{2}/Views/{1}/{0}.cshtml", "~/Areas/{2}/Views/Shared/{0}.cshtml" };
            base.AreaPartialViewLocationFormats = new string[] {"~/Areas/{2}/Views/{1}/{0}.cshtml","~/Areas/{2}/Views/Shared/{0}.cshtml"};
            base.ViewLocationFormats = new string[] { "~/Views/{1}/{0}.cshtml","~/Views/Shared/{0}.cshtml" };
            base.MasterLocationFormats = new string[] { "~/Views/{1}/{0}.cshtml","~/Views/Shared/{0}.cshtml" };
            base.PartialViewLocationFormats = new string[] {"~/Views/{1}/{0}.cshtml", "~/Views/Shared/{0}.cshtml" };
            base.FileExtensions = new string[] { "cshtml" };
        }
    }

在此繼承了 RazorViewEngine橡羞,如果看見代碼中的構造函數(shù),則會發(fā)現(xiàn)已指定所有可能存在文件的位置济舆,也包括可能的文件擴展名∏湓螅現(xiàn)在 Global.asax 內(nèi)使用此視圖引擎。

運行應用程序滋觉。

11個顯著提升 ASP.NET 應用程序性能的技巧——第1部分

現(xiàn)在應用程序查找 csharp razor 文件签夭,會獲得不錯的性能。

結論——本文介紹了可很容易用于任何 ASP.NET 應用程序的6個技巧:

1- 內(nèi)核模式緩存

2- Pipeline 模式

3- 刪除不用的模塊

4- 為所有請求運行所有托管模塊

5- 切勿在 wwwroot 內(nèi)寫入任何內(nèi)容

6- 刪除未使用的視圖引擎及語言

本系列后續(xù)博文將再介紹5個可用作應用程序性能提升器的技巧椎侠。敬請期待第租!

OneAPM 助您輕松鎖定 .NET 應用性能瓶頸,通過強大的 Trace 記錄逐層分析我纪,直至鎖定行級問題代碼慎宾。以用戶角度展示系統(tǒng)響應速度,以地域和瀏覽器維度統(tǒng)計用戶使用情況浅悉。想閱讀更多技術文章趟据,請訪問 OneAPM 官方博客

原文地址:
http://www.infragistics.com/community/blogs/devtoolsguy/archive/2015/08/07/12-tips-to-increase-the-performance-of-asp-net-application-drastically-part-1.aspx

本文轉(zhuǎn)自 OneAPM 官方博客

最后編輯于
?著作權歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末术健,一起剝皮案震驚了整個濱河市汹碱,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌荞估,老刑警劉巖咳促,帶你破解...
    沈念sama閱讀 211,948評論 6 492
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異勘伺,居然都是意外死亡跪腹,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,371評論 3 385
  • 文/潘曉璐 我一進店門娇昙,熙熙樓的掌柜王于貴愁眉苦臉地迎上來尺迂,“玉大人,你說我怎么就攤上這事≡朐#” “怎么了蹲盘?”我有些...
    開封第一講書人閱讀 157,490評論 0 348
  • 文/不壞的土叔 我叫張陵,是天一觀的道長膳音。 經(jīng)常有香客問我召衔,道長,這世上最難降的妖魔是什么祭陷? 我笑而不...
    開封第一講書人閱讀 56,521評論 1 284
  • 正文 為了忘掉前任苍凛,我火速辦了婚禮,結果婚禮上兵志,老公的妹妹穿的比我還像新娘醇蝴。我一直安慰自己,他們只是感情好想罕,可當我...
    茶點故事閱讀 65,627評論 6 386
  • 文/花漫 我一把揭開白布悠栓。 她就那樣靜靜地躺著,像睡著了一般按价。 火紅的嫁衣襯著肌膚如雪惭适。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 49,842評論 1 290
  • 那天楼镐,我揣著相機與錄音癞志,去河邊找鬼。 笑死框产,一個胖子當著我的面吹牛凄杯,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播秉宿,決...
    沈念sama閱讀 38,997評論 3 408
  • 文/蒼蘭香墨 我猛地睜開眼盾舌,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了蘸鲸?” 一聲冷哼從身側響起妖谴,我...
    開封第一講書人閱讀 37,741評論 0 268
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎酌摇,沒想到半個月后膝舅,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 44,203評論 1 303
  • 正文 獨居荒郊野嶺守林人離奇死亡窑多,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 36,534評論 2 327
  • 正文 我和宋清朗相戀三年仍稀,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片埂息。...
    茶點故事閱讀 38,673評論 1 341
  • 序言:一個原本活蹦亂跳的男人離奇死亡技潘,死狀恐怖遥巴,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情享幽,我是刑警寧澤铲掐,帶...
    沈念sama閱讀 34,339評論 4 330
  • 正文 年R本政府宣布,位于F島的核電站值桩,受9級特大地震影響摆霉,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜奔坟,卻給世界環(huán)境...
    茶點故事閱讀 39,955評論 3 313
  • 文/蒙蒙 一携栋、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧咳秉,春花似錦婉支、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,770評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至霎奢,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間饼灿,已是汗流浹背幕侠。 一陣腳步聲響...
    開封第一講書人閱讀 32,000評論 1 266
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留碍彭,地道東北人晤硕。 一個月前我還...
    沈念sama閱讀 46,394評論 2 360
  • 正文 我出身青樓,卻偏偏與公主長得像庇忌,于是被迫代替她去往敵國和親舞箍。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 43,562評論 2 349

推薦閱讀更多精彩內(nèi)容

  • 現(xiàn)在很多客戶也慢慢開始注重網(wǎng)站的性能了皆疹,同時有很多運營網(wǎng)站的公司也不像以前那樣特別在意網(wǎng)站是否非常漂亮疏橄,而把更多的...
    小明yz閱讀 929評論 0 13
  • Spring Cloud為開發(fā)人員提供了快速構建分布式系統(tǒng)中一些常見模式的工具(例如配置管理,服務發(fā)現(xiàn)略就,斷路器捎迫,智...
    卡卡羅2017閱讀 134,633評論 18 139
  • 原文地址:http://www.cnblogs.com/powertoolsteam/p/MVC_knowledg...
    寒劍飄零閱讀 8,614評論 5 170
  • Android 自定義View的各種姿勢1 Activity的顯示之ViewRootImpl詳解 Activity...
    passiontim閱讀 171,796評論 25 707
  • 雙子座喜歡追求新鮮感,有點兒小聰明表牢,就是耐心不夠窄绒,往往做事都是三分鐘熱度,難以堅持崔兴,但是你的可愛性格會讓很多人都喜...
    lfpwhy閱讀 701評論 0 3