訪問資料庫資源需要建立串連、開啟串連和關閉串連幾個操作。這些過程需要多次與資料庫交換資訊以通過身分識別驗證,比較耗費伺服器資源。 ASP.NET中提供了串連池(Connection Pool)改善開啟和關閉資料庫對效能的影響。系統將使用者的資料庫連接放在串連池中,需要時取出,關閉時收回串連,等待下一次的串連請求。串連池的大小是有限的,如果在串連池達到最大限度後仍要求建立串連,必然大大影響效能。因此,在建立資料庫連接後只有在真正需要操作時才開啟串連,使用完畢後馬上關閉,從而盡量減少資料庫連接開啟的時間,避免出現超出串連限制的情況。
使用預存程序
預存程序是儲存在伺服器上的一組先行編譯的SQL語句,類似於DOS系統中的批次檔。預存程序具有對資料庫立即訪問的功能,資訊處理極為迅速。使用預存程序可以避免對命令的多次編譯,在執行一次後其執行規劃就駐留在快取中,以後需要時只需直接調用緩衝中的二進位代碼即可。另外,預存程序在伺服器端運行,獨立於ASP.NET程式,便於修改,最重要的是它可以減少資料庫動作陳述式在網路中的傳輸。
最佳化查詢語句
ASP.NET中ADO串連消耗的資源相當大,SQL語句啟動並執行時間越長,佔用系統資源的時間也越長。因此,盡量使用最佳化過的SQL語句以減少執行時間。比如,不在查詢語句中包含子查詢語句,充分利用索引等。
字串操作效能最佳化
使用實值型別的ToString方法
在連接字串時,經常使用"+"號直接將數字添加到字串中。這種方法雖然簡單,也可以得到正確結果,但是由於涉及到不同的資料類型,數字需要通過裝箱操作轉化為參考型別才可以添加到字串中。但是裝箱操作對效能影響較大,因為在進行這類處理時,將在託管堆中分配一個新的對象,原有的值複製到新建立的對象中。使用實值型別的ToString方法可以避免裝箱操作,從而提高應用程式效能。
運用StringBuilder類
String類對象是不可改變的,對於String對象的重新賦值在本質上是重新建立了一個String對象並將新值賦予該對象,其方法 ToString對效能的提高並非很顯著。在處理字串時,最好使用StringBuilder類,其.NET 命名空間是System.Text。該類並非建立新的對象,而是通過Append,Remove,Insert等方法直接對字串進行操作,通過 ToString方法返回操作結果。
其定義及動作陳述式如下所示:
int num;</p><p> System.Text.StringBuilder str = new System.Text.StringBuilder(); //建立字串</p><p> str.Append(num.ToString()); //添加數值num</p><p> Response.Write(str.ToString); //顯示操作結果<br />
最佳化 Web 服務器電腦和特定應用程式的設定檔以符合您的特定需要
預設情況下,ASP.NET 配置被設定成啟用最廣泛的功能並盡量適應最常見的方案。因此,應用程式開發人員可以根據應用程式所使用的功能,最佳化和更改其中的某些配置,以提高應用程式的效能。下面的列表是您應該考慮的一些選項。
僅對需要的應用程式啟用身分識別驗證。
預設情況下,身分識別驗證模式為 Windows,或整合 NTLM。大多數情況下,對於需要身分識別驗證的應用程式,最好在 Machine.config 檔案中禁用身分識別驗證,並在 Web.config 檔案中啟用身分識別驗證。根據適當的請求和響應編碼設定來配置應用程式。ASP.NET 預設編碼格式為 UTF-8。如果您的應用程式為嚴格的 ASCII,請配置應用程式使用 ASCII 以獲得稍許的效能提高。
考慮對應用程式禁用 AutoEventWireup。
在 Machine.config 檔案中將 AutoEventWireup 屬性設定為 false,意味著頁面不將方法名與事件進行匹配和將兩者掛鈎(例如 Page_Load)。如果頁面開發人員要使用這些事件,需要在基類中重寫這些方法(例如,需要為頁面載入事件重寫 Page.OnLoad,而不是使用 Page_Load 方法)。如果禁用 AutoEventWireup,頁面將通過將事件串連留給頁面作者而不是自動執行它,獲得稍許的效能提升。
從請求處理管線中移除不用的模組。
預設情況下,伺服器電腦的 Machine.config 檔案中節點的所有功能均保留為啟用。根據應用程式所使用的功能,您可以從請求管線中移除不用的模組以獲得稍許的效能提升。檢查每個模組及其功能,並按您的需要自訂它。例如,如果您在應用程式中不使用工作階段狀態和輸出緩衝,則可以從列表中移除它們,以便請求在不執行其他有意義的處理時,不必執行每個模組的進入和離開代碼。
一定要禁用偵錯模式
在部署生產應用程式或進行任何效能測量之前,始終記住禁用偵錯模式。如果啟用了偵錯模式,應用程式的效能可能受到非常大的影響。
對於廣泛依賴外部資源的應用程式,請考慮在多處理器電腦上啟用網路園藝
ASP.NET 進程模型協助啟用多處理器電腦上的可縮放性,將工作分發給多個進程(每個CPU一個),並且每個進程都將處理器關係設定為其
CPU。此技術稱為網路園藝。如果應用程式使用較慢的資料庫伺服器或調用具有外部依賴項的 COM 物件(這裡只是提及兩種可能性),則為您的應用程式啟用網路園藝是有益的。但是,在決定啟用網路園藝之前,您應該測試應用程式在網路園中的執行情況。
只要可能,就快取資料和頁輸出
ASP.NET 提供了一些簡單的機制,它們會在不需要為每個頁請求動態計算頁輸出或資料時緩衝這些頁輸出或資料。另外,通過設計要進行緩衝的頁和資料請求(特別是在網站中預期將有較大通訊量的地區),可以最佳化這些頁的效能。與 .NET Framework 的任何 Web Form功能相比,適當地使用緩衝可以更好的提高網站的效能,有時這種提高是超數量級的。使用 ASP.NET 緩衝機制有兩點需要注意。首先,不要緩衝太多項。緩衝每個項均有開銷,特別是在記憶體使用量方面。不要緩衝容易重新計算和很少使用的項。其次,給緩衝的項分配的有效期間不要太短。很快到期的項會導致緩衝中不必要的周轉,並且經常導致更多的代碼清除和記憶體回收工作。若關心此問題,請監視與
ASP.NET Applications 效能物件關聯的 Cache Total Turnover Rate 效能計數器。高周轉率可能說明存在問題,特別是當項在到期前被移除時。這也稱作記憶體壓力。
選擇適合頁面或應用程式的資料查看機制
根據您選擇在 Web Form頁顯示資料的方式,在便利和效能之間常常存在著重要的權衡。例如,DataGrid Web
伺服器控制項可能是一種顯示資料的方便快捷的方法,但就效能而言它的開銷常常是最大的。在某些簡單的情況下,您通過產生適當的 HTML 自己呈現資料可能很有效,但是自訂和瀏覽器定向會很快抵銷所獲得的額外功效。Repeater Web 伺服器控制項是便利和效能的折衷。它高效、可自訂且可程式化。
將 SqlDataReader 類用於快速只進資料遊標
SqlDataReader 類提供了一種讀取從 SQL Server 資料庫檢索的只進資料流的方法。如果當建立 ASP.NET 應用程式時出現允許您使用它的情況,則 SqlDataReader 類提供比 DataSet 類更高的效能。情況之所以這樣,是因為 SqlDataReader 使用 SQL Server 的本機網路資料轉送格式從資料庫連接直接讀取資料。另外,SqlDataReader 類實現 IEnumerable 介面,該介面也允許您將資料繫結到伺服器控制項。有關更多資訊,請參見 SqlDataReader
類。有關 ASP.NET 如何訪問資料的資訊,請參見通過 ASP.NET 訪問資料。
將SQL Server 預存程序用於資料訪問
在 .NET Framework 提供的所有資料存取方法中,基於 SQL Server 的資料訪問是產生高效能、可縮放 Web 應用程式的推薦選擇。使用託管 SQL Server 提供者時,可通過使用編譯的預存程序而不是特殊查詢獲得額外的效能提高。
避免單一執行緒 Apartment (STA) COM 組件
預設情況下,ASP.NET 不允許任何 STA COM 組件在頁面內運行。若要運行它們,必須在 .aspx 檔案內將 ASPCompat=true 屬性包含在 @ Page 指令中。這樣就將執行用的線程池切換到 STA 線程池,而且使 HttpContext 和其他內建對象可用於 COM 物件。前者也是一種效能最佳化,因為它避免了將多執行緒 Apartment (MTA) 封送到 STA 線程的任何調用。使用 STA COM 組件可能大大損害效能,應盡量避免。若必須使用 STA COM 組件,如在任何 interop
方案中,則應在執行期間進行大量調用並在每次調用期間發送儘可能多的資訊。另外,小心不要在構造頁面期間建立任何 STA COM 組件。例如下面的代碼中,在頁面構造時將執行個體化由某個線程建立的 MySTAComponent,而該線程並不是將運行頁面的 STA 線程。這可能對效能有不利影響,因為要構造頁面就必須完成 MTA 和 STA 線程之間的封送處理。