(越辰家政軟件新聞)
訪問(wèn)數(shù)據(jù)庫(kù)資源需要?jiǎng)?chuàng)建連接、打開(kāi)連接和關(guān)閉連接幾個(gè)操作。這些過(guò)程需要多次與數(shù)據(jù)庫(kù)交換信息以通過(guò)身份驗(yàn)證,比較耗費(fèi)服務(wù)器資源……
數(shù)據(jù)庫(kù)的連接和關(guān)閉
訪問(wèn)數(shù)據(jù)庫(kù)資源需要?jiǎng)?chuàng)建連接、打開(kāi)連接和關(guān)閉連接幾個(gè)操作。這些過(guò)程需要多次與數(shù)據(jù)庫(kù)交換信息以通過(guò)身份驗(yàn)證,比較耗費(fèi)服務(wù)器資源。ASP.NET中提供了連接池(Connection Pool)改善打開(kāi)和關(guān)閉數(shù)據(jù)庫(kù)對(duì)性能的影響。系統(tǒng)將用戶的數(shù)據(jù)庫(kù)連接放在連接池中,需要時(shí)取出,關(guān)閉時(shí)收回連接,等待下一次的連接請(qǐng)求。連接池的大小是有限的,如果在連接池達(dá)到最大限度后仍要求創(chuàng)建連接,必然大大影響性能。因此,在建立數(shù)據(jù)庫(kù)連接后只有在真正需要操作時(shí)才打開(kāi)連接,使用完畢后馬上關(guān)閉,從而盡量減少數(shù)據(jù)庫(kù)連接打開(kāi)的時(shí)間,避免出現(xiàn)超出連接限制的情況。
使用存儲(chǔ)過(guò)程
存儲(chǔ)過(guò)程是存儲(chǔ)在服務(wù)器上的一組預(yù)編譯的SQL語(yǔ)句,類似于DOS系統(tǒng)中的批處理文件。存儲(chǔ)過(guò)程具有對(duì)數(shù)據(jù)庫(kù)立即訪問(wèn)的功能,信息處理極為迅速。使用存儲(chǔ)過(guò)程可以避免對(duì)命令的多次編譯,在執(zhí)行一次后其執(zhí)行規(guī)劃就駐留在高速緩存中,以后需要時(shí)只需直接調(diào)用緩存中的二進(jìn)制代碼即可。另外,存儲(chǔ)過(guò)程在服務(wù)器端運(yùn)行,獨(dú)立于ASP.NET程序,便于修改,最重要的是它可以減少數(shù)據(jù)庫(kù)操作語(yǔ)句在網(wǎng)絡(luò)中的傳輸。
優(yōu)化查詢語(yǔ)句
ASP.NET中ADO連接消耗的資源相當(dāng)大,SQL語(yǔ)句運(yùn)行的時(shí)間越長(zhǎng),占用系統(tǒng)資源的時(shí)間也越長(zhǎng)。因此,盡量使用優(yōu)化過(guò)的SQL語(yǔ)句以減少執(zhí)行時(shí)間。比如,不在查詢語(yǔ)句中包含子查詢語(yǔ)句,充分利用索引等。
字符串操作性能優(yōu)化
使用值類型的ToString方法
在連接字符串時(shí),經(jīng)常使用"+"號(hào)直接將數(shù)字添加到字符串中。這種方法雖然簡(jiǎn)單,也可以得到正確結(jié)果,但是由于涉及到不同的數(shù)據(jù)類型,數(shù)字需要通過(guò)裝箱操作轉(zhuǎn)化為引用類型才可以添加到字符串中。但是裝箱操作對(duì)性能影響較大,因?yàn)樵谶M(jìn)行這類處理時(shí),將在托管堆中分配一個(gè)新的對(duì)象,原有的值復(fù)制到新創(chuàng)建的對(duì)象中。使用值類型的ToString方法可以避免裝箱操作,從而提高應(yīng)用程序性能。
運(yùn)用StringBuilder類
String類對(duì)象是不可改變的,對(duì)于String對(duì)象的重新賦值在本質(zhì)上是重新創(chuàng)建了一個(gè)String對(duì)象并將新值賦予該對(duì)象,其方法ToString對(duì)性能的提高并非很顯著。在處理字符串時(shí),最好使用StringBuilder類,其.NET 命名空間是System.Text。該類并非創(chuàng)建新的對(duì)象,而是通過(guò)Append,Remove,Insert等方法直接對(duì)字符串進(jìn)行操作,通過(guò)ToString方法返回操作結(jié)果。 其定義及操作語(yǔ)句如下所示:
以下是代碼片段: int num; System.Text.StringBuilder str = new System.Text.StringBuilder(); //創(chuàng)建字符串 str.Append(num.ToString()); //添加數(shù)值num Response.Write(str.ToString); //顯示操作結(jié)果3. 優(yōu)化 Web 服務(wù)器計(jì)算機(jī)和特定應(yīng)用程序的配置文件以符合您的特定需要 |
默認(rèn)情況下,ASP.NET 配置被設(shè)置成啟用最廣泛的功能并盡量適應(yīng)最常見(jiàn)的方案。因此,應(yīng)用程序開(kāi)發(fā)人員可以根據(jù)應(yīng)用程序所使用的功能,優(yōu)化和更改其中的某些配置,以提高應(yīng)用程序的性能。下面的列表是您應(yīng)該考慮的一些選項(xiàng)。
僅對(duì)需要的應(yīng)用程序啟用身份驗(yàn)證。
默認(rèn)情況下,身份驗(yàn)證模式為 Windows,或集成 NTLM。大多數(shù)情況下,對(duì)于需要身份驗(yàn)證的應(yīng)用程序,最好在 Machine.config 文件中禁用身份驗(yàn)證,并在 Web.config 文件中啟用身份驗(yàn)證。根據(jù)適當(dāng)?shù)恼?qǐng)求和響應(yīng)編碼設(shè)置來(lái)配置應(yīng)用程序。ASP.NET 默認(rèn)編碼格式為 UTF-8。如果您的應(yīng)用程序?yàn)閲?yán)格的 ASCII,請(qǐng)配置應(yīng)用程序使用 ASCII 以獲得稍許的性能提高。
考慮對(duì)應(yīng)用程序禁用 AutoEventWireup。
在 Machine.config 文件中將 AutoEventWireup 屬性設(shè)置為 false,意味著頁(yè)面不將方法名與事件進(jìn)行匹配和將兩者掛鉤(例如 Page_Load)。如果頁(yè)面開(kāi)發(fā)人員要使用這些事件,需要在基類中重寫這些方法(例如,需要為頁(yè)面加載事件重寫 Page.OnLoad,而不是使用 Page_Load 方法)。如果禁用 AutoEventWireup,頁(yè)面將通過(guò)將事件連接留給頁(yè)面作者而不是自動(dòng)執(zhí)行它,獲得稍許的性能提升。
【 1 】 【 2 】 【 3 】 【 4 】 【 5 】 |