用什么方法提高.NET网站的性能<>

用什么方法提高.NET网站的性能

ZDNet软件频道 时间2009-12-15 作者:csdn | csdn
本文关键词:问答 asp.net

收集您的经验之你用什么方法提高.NET网站的性能

比如:尽量用StringBuilder代替使用字符串连接符 “+”.

一条足够烂的sql语句就能把你所有的优化工作废掉,数据库优化,这个应该排第一
缓存是所有web架构师的首选优化工具 。这个可以排第二

1。数据库优化。根据实际情况合理设计好数据表。
2。页面缓存。近来减少与数据库之间的连接次数。
3。页面图片不能太大,或者尽量少用图片,flash。
4。能使用存储过程尽量使用存储过程。

1.缓存。 (技术可以,用缓存池)
2.线程池。
3.图片分流。
4.样式图片组合成一张图片调用。
5.div+ul+li+css 设计网页
6.少用服务端控件。比如:gridview ,可以生成HTML,而无需用gridview

我认为.net网站真正的快速之道是:
1、前台用html表现,后台用ashx实现业务逻辑
2、html以Ajax方式连接ashx实现页面数据变化
优势是:即使网速慢或数据访问层效率低,也会被屏蔽,让用户感觉不到等待。
这种设计适合中小网站,且页面有频繁的数据交互情况。
很明显,这就是对过去传统CGI的再发挥,呵呵,现在很多年轻人可能不知道传统CGI是什么了吧,到是总听说PHP的CGI。
如果页面数据交互很少,仅是表现的话,那么可以直接生成纯静态页面。
这样的网站速度肯定是飞快的。

1)避免使用ArrayList。
    因为任何对象添加到ArrayList都要封箱为System.Object类型,从ArrayList取出数据时,要拆箱回实际的类型。建议使用自定义的集合类型代替ArrayList。.net 2.0提供了一个新的类型,叫泛型,这是一个强类型,使用泛型集合就可以避免了封箱和拆箱的发生,提高了性能。
2)使用HashTale代替其他字典集合类型(如StringDictionary,NameValueCollection,HybridCollection),存放少量数据的时候可以使用HashTable.
3)为字符串容器声明常量,不要直接把字符封装在双引号" "里面。
      //避免
      MyObject obj = new MyObject();
      obj.Status = "ACTIVE";

      //推荐
      const string C_STATUS = "ACTIVE";
      MyObject obj = new MyObject();
      obj.Status = C_STATUS;

4) 不要用UpperCase,Lowercase转换字符串进行比较,用String.Compare代替,它可以忽略大小写进行比较.
 
  例:
      const string C_VALUE = "COMPARE";
      if (String.Compare(sVariable, C_VALUE, true) == 0)
      {
      Console.Write("SAME");
      }

把数据序列化为二进制文件方便传输。
    我们在处理DataSet,DataTable对象时可以序列化为XML文件,如果要在网络传输,XML文件会产生内存,网络带宽等资源问题。这时我们就可以把它序列化为二进制文件,这样生成的文件会减少很多,代码如下:
      FileStream fs = new fileStream(@"XMLData.bin",FileMode.Create);
      BinaryFormatter bf = new BinaryFormatter();
      bf.Serialize(fs,XMLData);
      fs.colse();
    这样生成的二进制文件称为XMLBinary,用WINHEX直接打开还可以看到一些XML标记在里面,如果数据量很大,这时加一行代码:
    XMLData.RemortingFormat = SerializationFormat.Binary;
    这时生成的文件称为TrueBinary文件,当处理大量(超过10000行)时生成的文件尺寸是XMLBinary的几分之一。序列化的时候会自动保存模式,这样解序过程很简单。我还不知道解序比直接读取XML性能会下降多少。
使用DataTable的ImportRow方法。
      有些场合需要把大量数据从一个DataTable复制到另一个DataTable,使用DataTable的ImportRow方法可以大大提高性能,数据量少时没多大分别,当数据量到一万行以上时就可以明显的提高,可以达到几倍。

集中执行sql语句,
如:insert into aa(name)values('');select * form bb;

复杂的查询配合程序执行,
如:select * from users where name like '%abc%'
改成:select * from users
foreach datarow row in dt.rows
if row["name"].contains("abc") ..


比如说到dataset.
1、 利用索引加快查找行的效率
如果需要反复查找行,建议增加索引。有两种方式:
1)设置DataTable的PrimaryKey
    适用于按PrimaryKey查找行的情况。注意此时应调用DataTable.Rows.Find方法,一般惯用的Select方法不能利用索引。
2)使用DataView
    适用于按Non-PrimaryKey查找行的情况。可为DataTable创建一个DataView,并通过SortOrder参数指示建立索引。此后使用Find或FindRows查找行。


一、减少往返行程(Reduce Round Trips)
    使用下面的方法可以减少Web服务器和Browser之间的往返行程:
    1、为Browser启用缓存
    如果呈现的内容是静态的或变化周期较长,应启用Browser缓存,避免发出冗余的http请求。
    2、缓冲页面输出
    如果可能,则尽量缓冲页面输出,处理结束后再一次传送到客户端,这可以避免频繁传递小块内容所造成的多次网络交互。由于这种方式在页面处理结束之前客户端无法看到页面内容,因此如果一个页面的尺寸较大的话,可考虑使用Response.Flush方法。该方法强制输出迄今为止在缓冲区中的内容,你应当采用合理的算法控制调用Response.Flush方法的次数。

    3、使用Server.Transfer重定向请求
    使用Server.Transfer方法重定向请求优于Response.Redirect方法。原因是Response.Redirect会向Broswer回送一个响应头,在响应头中指出重定向的URL,之后Brower使用新的URL重新发出请求。而Server.Transfer方法直接是一个简单的服务端调用,完全没有这些开销!
    需要注意Server.Transfer有局限性:第一,它会跳过安全检查;第二,只适用于在同一Web应用内的页面间跳转。

二、避免阻塞和长时间的作业
    如果需要运行阻塞或长时间运行的操作,可以考虑使用异步调用的机制,以便Web服务器能够继续处理其它的请求。
    1、使用异步方式调用Web服务和远程对象
    只要有可能就要避免在请求的处理过程中对Web服务和远程对象的同步调用,因为它占用的是的ASP.NET 线程池中的工作线程,这将直接影响Web服务器响应其它请求的能力。

    2、考虑给不需要返回值的Web方法或远程对象的方法添加OneWay属性
    这种模式能让Web Server调用之后就立即返回。可根据实际情况决定是否使用这种方法。

    3、使用工作队列
    将作业提交到服务器上的工作队列中。客户端通过发送请求来轮询作业的执行结果。

三、 使用缓存
    缓存能在很大程度上决定ASP.NET应用的最终性能。Asp.net支持页面输出缓存和页面部分缓存,并提供Cache API,供应用程序缓存自己的数据。是否使用缓存可考虑下面的要点:
    1、识别创建与访问代价较大的数据
    2、评估需要缓存数据的易变性
    3、评估数据的使用频次
    4、 将要缓存数据中易变数据和不变数据分离,只缓存不变数据
        5、选择合适的缓存机制(除Asp.net Cache外,Application state和Session state也可以作为缓存使用)

四、多线程
    1、避免在请求处理过程中创建线程
    在执行请求的过程中创建线程是一种代价较大的操作,会严重影响Web Server的性能。如果后续的操作必须用线程完成,建议通过thread pool来创建/管理线程。

    2、不要依赖线程数据槽或线程静态变量
    由于执行请求的线程是ASP.NET thread pool中的工作线程,同一个Client的两次请求不一定由相同的线程来处理。

    3、避免阻塞处理请求的线程

    4、避免异步调用
    这和1的情况类似。异步调用会导致创建新的线程,增加服务器的负担。所以,如果没有并发的作业要执行,就不要执行异步调用。

五、 系统资源
    1、考虑实现资源池以提升性能
    2、明确地调用Dispose或Close释放系统资源
    3、不要缓存或长时间占用资源池中的资源
    4、尽可能晚的申请,尽可能早的释放

六、 页面处理
    1、尽量减小Page的尺寸
    包括缩短控件的名称、CSS的class的名称、去掉无谓空行和空格、禁用不需要的ViewState
    2、启用页面输出的缓冲区(Buffer)
    如果Buffer的机制被关闭,可以用下面的方法打开。
    使用程序打开页面输出缓存:
      Response.BufferOutput = true;
    使用@Page开关打开页面输出缓冲机制:
      <%@ Page Buffer = "true" %>

    使用Web.config或Machine.config配置文件的 <pages>节点:
      <pages buffer="true" …>
    3、利用Page.IsPostBack优化页面输出
    4、通过分离页面的不同的内容,来提高缓存效率和减少呈现的时间
    5、优化复杂和代价较大的循环
    6、合理利用客户端的计算资源,将一些操作转移到客户端进行

七、 ViewState
    ViewState是Asp.net为服务端控件在页面回传之间跟踪状态信息而设计的一种机制。
  1. 关闭ViewState
    如果不需要跟踪页面状态,例如页面不会 回传(PostBack)、不需要处理服务端控件事件或者每次页面刷新时都会重新计算控件内容,那么就不需要用ViewState来记录页面状态了。可以对特定的WebControl设置EnableViewState属性,也可以在页面一级设置:
    <%@ Page EnableViewState="false" %>

    2、在恰当的时间点初始化控件属性
    ASP.NET的控件在执行构造函数、初始化的期间设置的属性不会被跟踪变化;而在初始化阶段之后对属性的修改都会被跟踪,并最终记录到IE页面的__VIEWSTATE之中。所以,选择合理的初始化控件属性的执行点,能有效的减小页面尺寸。

    3、谨慎选择放到ViewState中的内容
    放到ViewState中的内容会被序列化/反序列化,Asp.net为String、Integer、Boolean等基本类型的序列化做了优化,如果Array、ArrayList、HashTable存储的是基本类型效率也较高,但其它类型则需要提供类型转换器(Type Converter),否则将使用代价昂贵的二进制序列化程序。

你可能感兴趣的:(.net)