數(shù)據(jù)庫的連接和關(guān)閉
訪問數(shù)據(jù)庫資源需要?jiǎng)?chuàng)建連接、打開連接和關(guān)閉連接幾個(gè)操作。這些過程需要多次與數(shù)據(jù)庫交換信息以通過身份驗(yàn)證,比較耗費(fèi)服務(wù)器資源。asp.net中提供了連接池(connection pool)改善打開和關(guān)閉數(shù)據(jù)庫對(duì)性能的影響。系統(tǒng)將用戶的數(shù)據(jù)庫連接放在連接池中,需要時(shí)取出,關(guān)閉時(shí)收回連接,等待下一次的連接請(qǐng)求。
連接池的大小是有限的,如果在連接池達(dá)到最大限度后仍要求創(chuàng)建連接,必然大大影響性能。因此,在建立數(shù)據(jù)庫連接后只有在真正需要操作時(shí)才打開連接,使用完畢后馬上關(guān)閉,從而盡量減少數(shù)據(jù)庫連接打開的時(shí)間,避免出現(xiàn)超出連接限制的情況。
使用存儲(chǔ)過程
存儲(chǔ)過程是存儲(chǔ)在服務(wù)器上的一組預(yù)編譯的sql語句,類似于dos系統(tǒng)中的批處理文件。存儲(chǔ)過程具有對(duì)數(shù)據(jù)庫立即訪問的功能,信息處理極為迅速。使用存儲(chǔ)過程可以避免對(duì)命令的多次編譯,在執(zhí)行一次后其執(zhí)行規(guī)劃就駐留在高速緩存中,以后需要時(shí)只需直接調(diào)用緩存中的二進(jìn)制代碼即可。
另外,存儲(chǔ)過程在服務(wù)器端運(yùn)行,獨(dú)立于asp.net程序,便于修改,最重要的是它可以減少數(shù)據(jù)庫操作語句在網(wǎng)絡(luò)中的傳輸。
優(yōu)化查詢語句
asp.net中ado連接消耗的資源相當(dāng)大,sql語句運(yùn)行的時(shí)間越長,占用系統(tǒng)資源的時(shí)間也越長。因此,盡量使用優(yōu)化過的sql語句以減少執(zhí)行時(shí)間。比如,不在查詢語句中包含子查詢語句,充分利用索引等。
2. 字符串操作性能優(yōu)化
使用值類型的tostring方法
  在連接字符串時(shí),經(jīng)常使用"+"號(hào)直接將數(shù)字添加到字符串中。這種方法雖然簡單,也可以得到正確結(jié)果,但是由于涉及到不同的數(shù)據(jù)類型,數(shù)字需要通過裝箱操作轉(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ì)象,而是通過append,remove,insert等方法直接對(duì)字符串進(jìn)行操作,通過tostring方法返回操作結(jié)果。
其定義及操作語句如下所示:
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)最常見的方案。因此,應(yīng)用程序開發(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è)置來配置應(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,意味著頁面不將方法名與事件進(jìn)行匹配和將兩者掛鉤(例如 page_load)。如果頁面開發(fā)人員要使用這些事件,需要在基類中重寫這些方法(例如,需要為頁面加載事件重寫 page.onload,而不是使用 page_load 方法)。如果禁用 autoeventwireup,頁面將通過將事件連接留給頁面作者而不是自動(dòng)執(zhí)行它,獲得稍許的性能提升。 
  從請(qǐng)求處理管線中移除不用的模塊。默認(rèn)情況下,服務(wù)器計(jì)算機(jī)的 machine.config 文件中 
例如,如果您在應(yīng)用程序中不使用會(huì)話狀態(tài)和輸出緩存,則可以從 
菜鳥學(xué)堂:
新聞熱點(diǎn)
疑難解答
圖片精選