一区二区三区日韩精品-日韩经典一区二区三区-五月激情综合丁香婷婷-欧美精品中文字幕专区

分享

分享提高ASP.NET Web應(yīng)用性能的技巧

 隱者黑鷹88 2016-02-13

在這篇文章中,將介紹一些提高 ASP.NET Web 應(yīng)用性能的方法和技巧。眾所周知,解決性能問(wèn)題是一項(xiàng)繁瑣的工作,當(dāng)出現(xiàn)性能問(wèn)題,每個(gè)人都會(huì)歸咎于編寫代碼的開發(fā)人員。

那性能問(wèn)題到底該如何解決?以下是應(yīng)用系統(tǒng)發(fā)布前,作為 .NET 開發(fā)人員需要檢查的點(diǎn)。

1.debug=「false」

當(dāng)創(chuàng)建 ASP.NET Web應(yīng)用程序,默認(rèn)設(shè)置為「true」。開發(fā)過(guò)程中,設(shè)置為「true」是非常有用多,但在應(yīng)用程序發(fā)布部署時(shí),需將其設(shè)置為「false」。

<compilation defaultLanguage="C#" debug="false" targetFramework="4.0" /> 

2.關(guān)閉 tracing(追蹤)

tracing 是非常可怕的,你有沒(méi)有忘記關(guān)閉它。假如沒(méi)用,請(qǐng)確定編輯 web.config 并且關(guān)閉它。它將占用大量您的程序資源。

<trace enabled="false" requestLimit=”10” pageoutput=”false” traceMode=”SortByTime” localOnly=”true”> 

3.禁用 session

假如您用不到 session 會(huì)話跟蹤請(qǐng)務(wù)必禁用它。您可以在每個(gè) asp.net 頁(yè)面中設(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ā)生請(qǐng)求超時(shí)。部署成發(fā)布版本,你將會(huì)發(fā)現(xiàn)速度有很大的提升。

5.關(guān)閉頁(yè)面的 View State

View State 主要是在提交以后回顯用的,它只有在頁(yè)面中的數(shù)據(jù)是提交到本頁(yè)時(shí)才有用。其默認(rèn)是「true」。如果你沒(méi)有使用表單數(shù)據(jù)回傳,那么可以關(guān)閉 View State。

<%@ Page EnableViewState="false" %> 

6.避免使用 Response.Redirect

Redirect(重定向)非常麻煩,它僅用于用于從當(dāng)前物理服務(wù)器開發(fā)跳轉(zhuǎn)到其它服務(wù)器。如果只是在本服務(wù)器開發(fā)內(nèi)頁(yè)面跳轉(zhuǎn)請(qǐng)使用 Server.Transfer 語(yǔ)法,這樣會(huì)減少很多沒(méi)有必要的客戶端重定向。

7.運(yùn)用 StringBuilder 類以及使用 ToString()方法

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é)果

8.避免拋出異常

異常會(huì)導(dǎo)致速度變慢,并且使得應(yīng)用程序頁(yè)面顯示異常,使得無(wú)法進(jìn)行其他操作??梢允褂?try / catch 使出現(xiàn)的異常記錄到日志文件中。

9.使用 finally 方法回收資源

假如你在應(yīng)用開發(fā)中大量使用其他數(shù)據(jù)庫(kù)連接和訪問(wèn)文件,請(qǐng)確定在用完后關(guān)閉它們。finally 塊是程序中最后被執(zhí)行,因此在這里面的代碼會(huì)確保一定會(huì)被執(zhí)行,關(guān)閉代碼一定要在這個(gè)開發(fā)方法塊中執(zhí)行。

10.使用客戶端腳本驗(yàn)證

用客戶端驗(yàn)證代替服務(wù)器開發(fā)端驗(yàn)證。服務(wù)器開發(fā)端數(shù)據(jù)驗(yàn)證將會(huì)大量消耗您的服務(wù)器開發(fā)上的資源,并且會(huì)代來(lái)大量的頁(yè)面數(shù)據(jù)回傳。

11.使用 Page.IsPostback

請(qǐng)確保不執(zhí)行過(guò)多的回傳代碼。使用 Page.IsPostBack 屬性,以確保只執(zhí)行頁(yè)面初始化邏輯,當(dāng)一個(gè)頁(yè)面第一次加載,而不向響應(yīng)客戶回發(fā)。

12.使用分頁(yè)

大多數(shù) Web 應(yīng)用程序數(shù)據(jù)是以表格形式顯示。分頁(yè)有利用應(yīng)用開發(fā)程序效率。每次盡量顯示小部分?jǐn)?shù)據(jù),這樣會(huì)加快頁(yè)面顯示速度。

13.使用 Ajax 異步調(diào)用

使用 Ajax 方法,進(jìn)行異步調(diào)用。

14.刪除未使用的 HttpModules

對(duì)于 httpModules,我們可以理解為:建立一個(gè)通用的可用被插入任何 Web 應(yīng)用程序的 HttpApplication 事件鉤子。使用 HttpModule 是可復(fù)用的,不需要特定語(yǔ)應(yīng)用程序代碼的,只需要 web.config 中的一個(gè)條目。 在 web.config 文件中,刪除未使用的 HttpModules。

15.避免遞歸函數(shù)/嵌套循環(huán)

在任何編程語(yǔ)言中都需避免嵌套循環(huán)和遞歸函數(shù),以提高性能。

16.不使用不必要的 Server Control

ASP.NET 中,大量的服務(wù)器端控件方便了程序開發(fā),但也可能帶來(lái)性能的損失,因?yàn)橛脩裘坎僮饕淮畏?wù)器端控件,就產(chǎn)生一次與服務(wù)器端的往返過(guò)程。因此,非必要,應(yīng)當(dāng)少使用 Server Control。

17.調(diào)用多個(gè)操作時(shí),請(qǐng)使用多線程

問(wèn)題出現(xiàn)時(shí),單線程卡在此問(wèn)題上長(zhǎng)時(shí)間運(yùn)行。因此,可以使用多個(gè)線程以提高應(yīng)用程序的響應(yīng)速度。

18.數(shù)據(jù)庫(kù)的連接和關(guān)閉

訪問(wèn)數(shù)據(jù)庫(kù)資源需要?jiǎng)?chuàng)建連接、打開連接和關(guān)閉連接幾個(gè)操作。這些過(guò)程需要多次與數(shù)據(jù)庫(kù)交換信息以通過(guò)身份驗(yàn)證,比較耗費(fèi)服務(wù)器資源。ASP.NET 中提供了連接池(Connection Pool)改善打開和關(guān)閉數(shù)據(jù)庫(kù)對(duì)性能的影響。系統(tǒng)將用戶的數(shù)據(jù)庫(kù)連接放在連接池中,需要時(shí)取出,關(guān)閉時(shí)收回連接,等待下一次的連接請(qǐng)求。連接池的大小是有限的,如果在連接池達(dá)到最大限度后仍要求創(chuàng)建連接,必然大大影響性能。因此,在建立數(shù)據(jù)庫(kù)連接后只有在真正需要操作時(shí)才打開連接,使用完畢后馬上關(guān)閉,從而盡量減少數(shù)據(jù)庫(kù)連接打開的時(shí)間,避免出現(xiàn)超出連接限制的情況。

19.將 SqlDataReader 類用于快速只進(jìn)數(shù)據(jù)游標(biāo)

SqlDataReader 類提供了一種讀取從 SQL Server 數(shù)據(jù)庫(kù)檢索的只進(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ù)庫(kù)連接直接讀取數(shù)據(jù)。另外,SqlDataReader 類實(shí)現(xiàn) IEnumerable 接口,該接口也允許您將數(shù)據(jù)綁定到服務(wù)器控件。有關(guān)更多信息,請(qǐng)參見(jiàn) SqlDataReader 類。有關(guān) ASP.NET 如何訪問(wèn)數(shù)據(jù)的信息,請(qǐng)參見(jiàn)通過(guò) ASP.NET 訪問(wèn)數(shù)據(jù)。

20.高性能的 SQL 語(yǔ)句規(guī)則

  • 盡量避免全表掃描
  • 盡量避免在 where 子句中對(duì)字段進(jìn)行 null 值判斷
  • 盡量避免在 where 子句中使用 != 或 <> 操作符
  • 盡量避免在 where 子句中使用 or 來(lái)連接條件
  • in 和 not in 也要慎用
  • 不要在 where 子句中的「=」左邊進(jìn)行函數(shù)、算術(shù)運(yùn)算或其他表達(dá)式運(yùn)算
  • Update 語(yǔ)句,如果只更改1、2個(gè)字段,不要Update全部字段
  • 對(duì)于多張大數(shù)據(jù)量(這里幾百條就算大了)的表JOIN,要先分頁(yè)再JOIN,否則邏輯讀會(huì)很高,性能很差
  • 盡可能的使用 varchar/nvarchar 代替 char/nchar 

21.緩存

緩存是一種用空間換取時(shí)間的技術(shù),通俗點(diǎn)也就是說(shuō)把你得到的數(shù)據(jù)存放在內(nèi)存中一段時(shí)間,在這短時(shí)間內(nèi)服務(wù)器不去讀取數(shù)據(jù)庫(kù)、或是真實(shí)的數(shù)據(jù)源,而是讀取你存放在內(nèi)存中的數(shù)據(jù)。 緩存是網(wǎng)站性能優(yōu)化不可缺少的一種數(shù)據(jù)處理機(jī)制,他能有效的緩解數(shù)據(jù)庫(kù)壓力。 ASP.NET 中的緩存主要分為:

  • 頁(yè)面緩存
  • 數(shù)據(jù)源緩存
  • 自定義數(shù)據(jù)緩存

22.做負(fù)載均衡和服務(wù)器加成

負(fù)載均衡不應(yīng)該僅僅被看作是實(shí)現(xiàn)可擴(kuò)展性的一種手段。盡管它肯定提高了可擴(kuò)展性,很多時(shí)候它增加了 Web 應(yīng)用程序的性能,因?yàn)檎?qǐng)求和用戶都散發(fā)著多個(gè)服務(wù)器。

23.通過(guò) FxCop 做代碼檢查和優(yōu)化

FxCop 是一個(gè)代碼分析工具,它使用基于規(guī)則的引擎,來(lái)檢查出你代碼中不合規(guī)范的部分;你也可以定制自己的規(guī)則加入到這個(gè)引擎。其中的一些規(guī)則是:

  • 避免過(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ù)器

以上是一些性能調(diào)整的提示。性能調(diào)優(yōu)不是一天兩天的工作,而是一個(gè)反反復(fù)復(fù)的過(guò)程。對(duì)于網(wǎng)站開發(fā)人員來(lái)說(shuō),在編寫 ASP.NET 應(yīng)用程序時(shí)注意性能問(wèn)題,養(yǎng)成良好的習(xí)慣,提高應(yīng)用程序性能,至少可以推遲必需的硬件升級(jí),降低網(wǎng)站的成本。

    本站是提供個(gè)人知識(shí)管理的網(wǎng)絡(luò)存儲(chǔ)空間,所有內(nèi)容均由用戶發(fā)布,不代表本站觀點(diǎn)。請(qǐng)注意甄別內(nèi)容中的聯(lián)系方式、誘導(dǎo)購(gòu)買等信息,謹(jǐn)防詐騙。如發(fā)現(xiàn)有害或侵權(quán)內(nèi)容,請(qǐng)點(diǎn)擊一鍵舉報(bào)。
    轉(zhuǎn)藏 分享 獻(xiàn)花(0

    0條評(píng)論

    發(fā)表

    請(qǐng)遵守用戶 評(píng)論公約

    類似文章 更多

    日本大学生精油按摩在线观看| 草草视频福利在线观看| 成人精品日韩专区在线观看| 东北女人的逼操的舒服吗| 99久久精品久久免费| 日本最新不卡免费一区二区| 中文字幕无线码一区欧美| 欧美日韩有码一二三区| 久草国产精品一区二区| 日韩欧美国产亚洲一区| 欧洲自拍偷拍一区二区| 欧美特色特黄一级大黄片| 免费一区二区三区少妇| 日韩人妻欧美一区二区久久| 欧美乱妇日本乱码特黄大片| 久久99国产精品果冻传媒| 午夜精品国产一区在线观看| 日韩精品视频高清在线观看| 国产精品午夜性色视频| 女厕偷窥一区二区三区在线| 好吊色欧美一区二区三区顽频| 青青操日老女人的穴穴| 国产精品欧美激情在线观看| 午夜福利激情性生活免费视频| 最近的中文字幕一区二区| 精品欧美一区二区三久久| 久久碰国产一区二区三区| 自拍偷拍一区二区三区| 欧美日韩综合免费视频| 中文字幕精品一区二区年下载| 99精品国产一区二区青青| 麻豆精品视频一二三区| 欧美日韩精品久久第一页| 在线免费国产一区二区| 国产精品内射婷婷一级二级| 久久热麻豆国产精品视频| 成年男女午夜久久久精品| 久久精品视频就在久久| 国产日韩欧美在线播放| 人妻少妇久久中文字幕久久| 欧美精品在线播放一区二区|