十年網(wǎng)站開發(fā)經(jīng)驗(yàn) + 多家企業(yè)客戶 + 靠譜的建站團(tuán)隊(duì)
量身定制 + 運(yùn)營維護(hù)+專業(yè)推廣+無憂售后,網(wǎng)站問題一站解決
這篇文章主要介紹如何提高ASP.NET Web應(yīng)用性能,文中介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們一定要看完!
1.debug=「false」
當(dāng)創(chuàng)建 ASP.NET Web應(yīng)用程序,默認(rèn)設(shè)置為「true」。開發(fā)過程中,設(shè)置為「true」是非常有用多,但在應(yīng)用程序發(fā)布部署時(shí),需將其設(shè)置為「false」。
2.關(guān)閉 tracing(追蹤)
tracing 是非常可怕的,你有沒有忘記關(guān)閉它。假如沒用,請確定編輯 web.config 并且關(guān)閉它。它將占用大量您的程序資源。
3.禁用 session
假如您用不到 session 會話跟蹤請務(wù)必禁用它。您可以在每個(gè) asp.net 頁面中設(shè)置如下:
<%@ page language="c#" codebehind="webform1.aspx.cs" autoeventwireup="false" inherits="webapplication1.webform1" enablesessionstate="false" %>
4.使用發(fā)布版本部署應(yīng)用
部署應(yīng)用程序到生產(chǎn)環(huán)境時(shí),要確保使用的發(fā)布版本模式,而不是調(diào)試模式。如果使用調(diào)試模板極容易發(fā)生請求超時(shí)。部署成發(fā)布版本,你將會發(fā)現(xiàn)速度有很大的提升。
5.關(guān)閉頁面的 View State
View State 主要是在提交以后回顯用的,它只有在頁面中的數(shù)據(jù)是提交到本頁時(shí)才有用。其默認(rèn)是「true」。如果你沒有使用表單數(shù)據(jù)回傳,那么可以關(guān)閉 View State。
<%@ Page EnableViewState="false" %>
6.避免使用 Response.Redirect
Redirect(重定向)非常麻煩,它僅用于用于從當(dāng)前物理服務(wù)器開發(fā)跳轉(zhuǎn)到其它服務(wù)器。如果只是在本服務(wù)器開發(fā)內(nèi)頁面跳轉(zhuǎn)請使用 Server.Transfer 語法,這樣會減少很多沒有必要的客戶端重定向。
7.運(yùn)用 StringBuilder 類以及使用 ToString()方法
String 類對象是不可改變的,對于 String 對象的重新賦值在本質(zhì)上是重新創(chuàng)建了一個(gè) String 對象并將新值賦予該對象,其方法 ToString 對性能的提高并非很顯著。在處理字符串時(shí),好使用 StringBuilder 類,其 .NET 命名空間是 System.Text。該類并非創(chuàng)建新的對象,而是通過 Append,Remove,Insert 等方法直接對字符串進(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é)果
8.避免拋出異常
異常會導(dǎo)致速度變慢,并且使得應(yīng)用程序頁面顯示異常,使得無法進(jìn)行其他操作??梢允褂?try / catch 使出現(xiàn)的異常記錄到日志文件中。
9.使用 finally 方法回收資源
假如你在應(yīng)用開發(fā)中大量使用其他數(shù)據(jù)庫連接和訪問文件,請確定在用完后關(guān)閉它們。finally 塊是程序中最后被執(zhí)行,因此在這里面的代碼會確保一定會被執(zhí)行,關(guān)閉代碼一定要在這個(gè)開發(fā)方法塊中執(zhí)行。
10.使用客戶端腳本驗(yàn)證
用客戶端驗(yàn)證代替服務(wù)器開發(fā)端驗(yàn)證。服務(wù)器開發(fā)端數(shù)據(jù)驗(yàn)證將會大量消耗您的服務(wù)器開發(fā)上的資源,并且會代來大量的頁面數(shù)據(jù)回傳。
11.使用 Page.IsPostback
請確保不執(zhí)行過多的回傳代碼。使用 Page.IsPostBack 屬性,以確保只執(zhí)行頁面初始化邏輯,當(dāng)一個(gè)頁面第一次加載,而不向響應(yīng)客戶回發(fā)。
12.使用分頁
大多數(shù) Web 應(yīng)用程序數(shù)據(jù)是以表格形式顯示。分頁有利用應(yīng)用開發(fā)程序效率。每次盡量顯示小部分?jǐn)?shù)據(jù),這樣會加快頁面顯示速度。
13.使用 Ajax 異步調(diào)用
使用 Ajax 方法,進(jìn)行異步調(diào)用。
14.刪除未使用的 HttpModules
對于 httpModules,我們可以理解為:建立一個(gè)通用的可用被插入任何 Web 應(yīng)用程序的 HttpApplication 事件鉤子。使用 HttpModule 是可復(fù)用的,不需要特定語應(yīng)用程序代碼的,只需要 web.config 中的一個(gè)條目。 在 web.config 文件中,刪除未使用的 HttpModules。
15.避免遞歸函數(shù)/嵌套循環(huán)
在任何編程語言中都需避免嵌套循環(huán)和遞歸函數(shù),以提高性能。
16.不使用不必要的 Server Control
ASP.NET 中,大量的服務(wù)器端控件方便了程序開發(fā),但也可能帶來性能的損失,因?yàn)橛脩裘坎僮饕淮畏?wù)器端控件,就產(chǎn)生一次與服務(wù)器端的往返過程。因此,非必要,應(yīng)當(dāng)少使用 Server Control。
17.調(diào)用多個(gè)操作時(shí),請使用多線程
問題出現(xiàn)時(shí),單線程卡在此問題上長時(shí)間運(yùn)行。因此,可以使用多個(gè)線程以提高應(yīng)用程序的響應(yīng)速度。
18.數(shù)據(jù)庫的連接和關(guān)閉
訪問數(shù)據(jù)庫資源需要創(chuàng)建連接、打開連接和關(guān)閉連接幾個(gè)操作。這些過程需要多次與數(shù)據(jù)庫交換信息以通過身份驗(yàn)證,比較耗費(fèi)服務(wù)器資源。ASP.NET 中提供了連接池(Connection Pool)改善打開和關(guān)閉數(shù)據(jù)庫對性能的影響。系統(tǒng)將用戶的數(shù)據(jù)庫連接放在連接池中,需要時(shí)取出,關(guān)閉時(shí)收回連接,等待下一次的連接請求。連接池的大小是有限的,如果在連接池達(dá)到較大限度后仍要求創(chuàng)建連接,必然大大影響性能。因此,在建立數(shù)據(jù)庫連接后只有在真正需要操作時(shí)才打開連接,使用完畢后馬上關(guān)閉,從而盡量減少數(shù)據(jù)庫連接打開的時(shí)間,避免出現(xiàn)超出連接限制的情況。
19.將 SqlDataReader 類用于快速只進(jìn)數(shù)據(jù)游標(biāo)
SqlDataReader 類提供了一種讀取從 SQL Server 數(shù)據(jù)庫檢索的只進(jìn)數(shù)據(jù)流的方法。如果當(dāng)創(chuàng)建 ASP.NET 應(yīng)用程序時(shí)出現(xiàn)允許您使用它的情況,則 SqlDataReader 類提供比 DataSet 類更高的性能。情況之所以這樣,是因?yàn)?SqlDataReader 使用 SQL Server 的本機(jī)網(wǎng)絡(luò)數(shù)據(jù)傳輸格式從數(shù)據(jù)庫連接直接讀取數(shù)據(jù)。另外,SqlDataReader 類實(shí)現(xiàn) IEnumerable 接口,該接口也允許您將數(shù)據(jù)綁定到服務(wù)器控件。有關(guān)更多信息,請參見 SqlDataReader 類。有關(guān) ASP.NET 如何訪問數(shù)據(jù)的信息,請參見通過 ASP.NET 訪問數(shù)據(jù)。
20.高性能的 SQL 語句規(guī)則
盡量避免全表掃描
盡量避免在 where 子句中對字段進(jìn)行 null 值判斷
盡量避免在 where 子句中使用 != 或 <> 操作符
盡量避免在 where 子句中使用 or 來連接條件
in 和 not in 也要慎用
不要在 where 子句中的「=」左邊進(jìn)行函數(shù)、算術(shù)運(yùn)算或其他表達(dá)式運(yùn)算
Update 語句,如果只更改1、2個(gè)字段,不要Update全部字段
對于多張大數(shù)據(jù)量(這里幾百條就算大了)的表JOIN,要先分頁再JOIN,否則邏輯讀會很高,性能很差
盡可能的使用 varchar/nvarchar 代替 char/nchar
21.緩存
緩存是一種用空間換取時(shí)間的技術(shù),通俗點(diǎn)也就是說把你得到的數(shù)據(jù)存放在內(nèi)存中一段時(shí)間,在這短時(shí)間內(nèi)服務(wù)器不去讀取數(shù)據(jù)庫、或是真實(shí)的數(shù)據(jù)源,而是讀取你存放在內(nèi)存中的數(shù)據(jù)。 緩存是網(wǎng)站性能優(yōu)化不可缺少的一種數(shù)據(jù)處理機(jī)制,他能有效的緩解數(shù)據(jù)庫壓力。 ASP.NET 中的緩存主要分為:
頁面緩存
數(shù)據(jù)源緩存
自定義數(shù)據(jù)緩存
22.做負(fù)載均衡和服務(wù)器加成
負(fù)載均衡不應(yīng)該僅僅被看作是實(shí)現(xiàn)可擴(kuò)展性的一種手段。盡管它肯定提高了可擴(kuò)展性,很多時(shí)候它增加了 Web 應(yīng)用程序的性能,因?yàn)檎埱蠛陀脩舳忌l(fā)著多個(gè)服務(wù)器。
23.通過 FxCop 做代碼檢查和優(yōu)化
FxCop 是一個(gè)代碼分析工具,它使用基于規(guī)則的引擎,來檢查出你代碼中不合規(guī)范的部分;你也可以定制自己的規(guī)則加入到這個(gè)引擎。其中的一些規(guī)則是:
避免過多的局部變量
避免使用未調(diào)用的私有代碼
避免未實(shí)例化的內(nèi)部類
避免使用未密封的特性
避免進(jìn)行不必要的強(qiáng)制轉(zhuǎn)換
以內(nèi)聯(lián)方式初始化引用類型的靜態(tài)字段
用 NeutralResourcesLanguageAttribute 標(biāo)記程序集
將成員標(biāo)記為 Static 等等。
24.ASP.NET 性能監(jiān)控工具
這些是用于監(jiān)視代碼的性能的工具。
.NET 內(nèi)存分析器
Red Gate ANTS 性能分析工具
Fiddler
性能計(jì)數(shù)器
以上是“如何提高ASP.NET Web應(yīng)用性能”這篇文章的所有內(nèi)容,感謝各位的閱讀!希望分享的內(nèi)容對大家有幫助,更多相關(guān)知識,歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道!