1.數據庫訪問性能優化
數據庫的連接和關閉
訪問數據庫資源需要創建連接、打開連接和關閉連接幾個操作。這些過程需要多次與數據庫交換信息 以通過身份驗證,比較耗費服務器資源。ASP.NET中提供了連接池(Connection Pool)改善打開和關閉數據 庫對性能的影響。系統將用戶的數據庫連接放在連接池中,需要時取出,關閉時收回連接,等待下一次的 連接請求。連接池的大小是有限的,如果在連接池達到最大限度後仍要求創建連接,必然大大影響性能。 因此,在建立數據庫連接後只有在真正需要操作時才打開連接,使用完畢後馬上關閉,從而盡量減少數據 庫連接打開的時間,避免出現超出連接限制的情況。
使用存儲過程
存儲過程是存儲在服務器上的一組預編譯的SQL語句,類似於DOS系統中的批處理文件。存儲過程具有 對數據庫立即訪問的功能,信息處理極為迅速。使用存儲過程可以避免對命令的多次編譯,在執行一次後 其執行規劃就駐留在高速緩存中,以後需要時只需直接調用緩存中的二進制代碼即可。另外,存儲過程在 服務器端運行,獨立於ASP.NET程序,便於修改,最重要的是它可以減少數據庫操作語句在網絡中的傳輸 。
優化查詢語句
ASP.NET中ADO連接消耗的資源相當大,SQL語句運行的時間越長,占用系統資源的時間也越長。因此, 盡量使用優化過的SQL語句以減少執行時間。比如,不在查詢語句中包含子查詢語句,充分利用索引等。
2.字符串操作性能優化
使用值類型的ToString方法
在連接字符串時,經常使用"+"號直接將數字添加到字符串中。這種方法雖然簡單,也可以得到正確結 果,但是由於涉及到不同的數據類型,數字需要通過裝箱操作轉化為引用類型才可以添加到字符串中。但 是裝箱操作對性能影響較大,因為在進行這類處理時,將在托管堆中分配一個新的對象,原有的值復制到 新創建的對象中。使用值類型的ToString方法可以避免裝箱操作,從而提高應用程序性能。
運用StringBuilder類
String類對象是不可改變的,對於String對象的重新賦值在本質上是重新創建了一個String對象並將 新值賦予該對象,其方法ToString對性能的提高並非很顯著。在處理字符串時,最好使用StringBuilder 類,其.NET 命名空間是System.Text。該類並非創建新的對象,而是通過Append,Remove,Insert等方法 直接對字符串進行操作,通過ToString方法返回操作結果。
其定義及操作語句如下所示:
int num;
System.Text.StringBuilder str = new System.Text.StringBuilder(); //創建字符串
str.Append(num.ToString()); //添加數值num
Response.Write(str.ToString); //顯示操作結果3.優化 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 文件中 節點的所有功能均保留為激活。根據應用程序 所使用的功能,您可以從請求管線中移除不用的模塊以獲得稍許的性能提升。檢查每個模塊及其功能,並 按您的需要自定義它。例如,如果您在應用程序中不使用會話狀態和輸出緩存,則可以從 列表中移除它 們,以便請求在不執行其他有意義的處理時,不必執行每個模塊的進入和離開代碼。