溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點(diǎn)擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

11個(gè)顯著提升 ASP.NET 應(yīng)用程序性能的技巧——第1部分

發(fā)布時(shí)間:2020-09-04 07:27:06 來源:網(wǎng)絡(luò) 閱讀:177 作者:OneAPM123 欄目:編程語言

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

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

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

11個(gè)顯著提升 ASP.NET 應(yīng)用程序性能的技巧——第1部分

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

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

11個(gè)顯著提升 ASP.NET 應(yīng)用程序性能的技巧——第1部分

首先需要在第一個(gè)紅框內(nèi)確定緩存至內(nèi)核的文件擴(kuò)展名,然后選中第二個(gè)紅框內(nèi)的復(fù)選框。第三個(gè)紅框內(nèi)為使緩存失效的三個(gè)選項(xiàng),可根據(jù)具體需求進(jìn)行設(shè)置。

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

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

選擇相應(yīng)應(yīng)用程序池并右擊屬性,便可設(shè)置/更新 Pipeline 模式。

11個(gè)顯著提升 ASP.NET 應(yīng)用程序性能的技巧——第1部分

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

注:切勿盲目更改設(shè)置。如果應(yīng)用程序來自 IIS6,則可能對 IIS6 存在一定依賴性。因此,徹底更改設(shè)置后,進(jìn)行測試后方可進(jìn)入下一步。

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

11個(gè)顯著提升 ASP.NET 應(yīng)用程序性能的技巧——第1部分

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

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

得到的模塊可綁定至任何控件,具體結(jié)果如下:

11個(gè)顯著提升 ASP.NET 應(yīng)用程序性能的技巧——第1部分

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

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

此處,采用刪除標(biāo)記列出需要?jiǎng)h除的模塊。由于在此刪除了5個(gè)模塊,下次查看現(xiàn)用模塊便只有13個(gè)。

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

4- 為所有請求運(yùn)行所有托管模塊——這是存在于 web.config 或 applicationHost.config中的另一配置,通過以下代碼設(shè)置對IIS 上所有應(yīng)用程序有效。

<modules runAllManagedModulesForAllRequests="true">

這意味著,可為到達(dá)應(yīng)用程序的所有請求運(yùn)行所有模塊,但由于只需運(yùn)行 ASP.NET 文件而非 css、js、jpg、html等其他文件,因此通常不需要運(yùn)行所有模塊。也就是說,即使這些資源的請求經(jīng)過 Pipeline,但這些文件并不需要通過 Pipeline,因?yàn)檫@樣只會(huì)增加額外開支,但不能僅僅在應(yīng)用程序級(jí)設(shè)置為假。因此,可通過以下兩種方式解決:

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

b) 或者在同一應(yīng)用程序中,將所有靜態(tài)資源放入一個(gè)文件夾,添加針對該文件夾的 web.config 文件,并將其設(shè)置為假。

5- 切勿在文件夾 c:\inetpub\wwwroot中寫入任何內(nèi)容——文件觀察程序會(huì)查看文件夾,如果文件夾出現(xiàn)任何變更,文件觀察程序便會(huì)重啟相應(yīng)的應(yīng)用程序池。此功能在 IIS 中可用,如果 web.config 或任何文件出現(xiàn)任何變更,文件觀察程序便會(huì)重啟應(yīng)用程序池,使得修改后的應(yīng)用程序可處理請求。現(xiàn)在假設(shè)將應(yīng)用程序日志寫入應(yīng)用程序文件夾內(nèi)的文本文件內(nèi),使得各請求均有幾個(gè)條目,從而導(dǎo)致應(yīng)用程序池會(huì)多次重啟,這對應(yīng)用程序具有危害性。因此,與此相反,請勿在此文件夾內(nèi)寫入或變更任何內(nèi)容,直至此文件不再是 application binaries 的一部分。

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

11個(gè)顯著提升 ASP.NET 應(yīng)用程序性能的技巧——第1部分

上圖表明應(yīng)用程序在查找所有可能位置的 razor 和 aspx 文件。但是由于已知使用的是 razor 視圖引擎并且查找其他 aspx 文件并不能解決問題,因此不應(yīng)浪費(fèi)時(shí)間查找其他 aspx 文件,從而應(yīng)刪除多余的視圖引擎。需要采用 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)在再次運(yùn)行應(yīng)用程序。

11個(gè)顯著提升 ASP.NET 應(yīng)用程序性能的技巧——第1部分

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

b) 仔細(xì)看以上截圖可發(fā)現(xiàn)應(yīng)用程序在查找 c# 和 vb 文件,假設(shè)解決方案中從未使用 vb,因此查找 vbhtml 文件并無任何作用。欲解決這個(gè)問題,需要編寫自定義的視圖引擎。因此,按照以下方法編寫自定義 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,如果看見代碼中的構(gòu)造函數(shù),則會(huì)發(fā)現(xiàn)已指定所有可能存在文件的位置,也包括可能的文件擴(kuò)展名。現(xiàn)在 Global.asax 內(nèi)使用此視圖引擎。

運(yùn)行應(yīng)用程序。

11個(gè)顯著提升 ASP.NET 應(yīng)用程序性能的技巧——第1部分

現(xiàn)在應(yīng)用程序查找 csharp razor 文件,會(huì)獲得不錯(cuò)的性能。

結(jié)論——本文介紹了可很容易用于任何 ASP.NET 應(yīng)用程序的6個(gè)技巧:

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

2- Pipeline 模式

3- 刪除不用的模塊

4- 為所有請求運(yùn)行所有托管模塊

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

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

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

OneAPM 助您輕松鎖定 .NET 應(yīng)用性能瓶頸,通過強(qiáng)大的 Trace 記錄逐層分析,直至鎖定行級(jí)問題代碼。以用戶角度展示系統(tǒng)響應(yīng)速度,以地域和瀏覽器維度統(tǒng)計(jì)用戶使用情況。想閱讀更多技術(shù)文章,請?jiān)L問 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 官方博客


向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI