常用的net性能优化方法

上传人:s9****2 文档编号:486195969 上传时间:2023-11-16 格式:DOCX 页数:9 大小:27.26KB
返回 下载 相关 举报
常用的net性能优化方法_第1页
第1页 / 共9页
常用的net性能优化方法_第2页
第2页 / 共9页
常用的net性能优化方法_第3页
第3页 / 共9页
常用的net性能优化方法_第4页
第4页 / 共9页
常用的net性能优化方法_第5页
第5页 / 共9页
点击查看更多>>
资源描述

《常用的net性能优化方法》由会员分享,可在线阅读,更多相关《常用的net性能优化方法(9页珍藏版)》请在金锄头文库上搜索。

1、1. 数据库访问性能优化 数据库的连接和关闭 访问数据库资源需要创建连接、打开连接和关闭连接几个操作。这些过程需要多次与数据库 交换信息以通过身份验证,比较耗费服务器资源。ASP.NET中提供了连接池(Connection Pool) 改善打开和关闭数据库对性能的影响。系统将用户的数据库连接放在连接池中,需要时取出, 关闭时收回连接,等待下一次的连接请求。连接池的大小是有限的,R1如果在连接池达到 最大限度后仍要求创建连接,必然大大影响性能因此,在建立数据库连接后只有在真正需 要操作时才扛开连接亠使用完毕后马上关闭从而尽量减少数据库连接扛开的时间,避免出 现超出连接限制的情况。使用存储过程存储

2、过程是存储在服务器上的一组预编译的SQL语句,类似于DOS系统中的批处理文件。 存储过程具有对数据库立即访问的功能,信息处理极为迅速。使用存储过程可以避免对命令 的多次编译,在执行一次后其执行规划就驻留在高速缓存中,以后需要时只需直接调用缓存 中的二进制代码即可。另外,存储过程在服务器端运行,独立于ASP.NET程序,便于修改, 最重要的是它可以减少数据库操作语句在网络中的传输。优化查询语句ASP.NET中ADO连接消耗的资源相当大,SQL语句运行的时间越长,占用系统资源的时间 也越长。因此,R2尽量使用优化过的.SQL语句以减少执行时间。比如,不在查询语句中包 含子查询语句,充分利用索引等2

3、. 字符串操作性能优化使用值类型的ToString方法在连接字符串时,经常使用+号直接将数字添加到字符串中。这种方法虽然简单,也可以 得到正确结果,但是由于涉及到不同的数据类型,数字需要通过装箱操作转化为引用类型才 可以添加到字符串中。但是装箱操作对性能影响较大,因为在进行这类处理时,将在托管堆 中分配一个新的对象,原有的值复制到新创建的对象中。R3.使用值类.型的.ToString.方法可 以避免装箱操作,从而提高应用程序性能。运用 StringBuilder 类String类对象是不可改变的,对于String对象的重新赋值在本质上是重新创建了一个String 对象并将新值赋予该对象,其方法

4、ToString对性能的提高并非很显著。R4在处理字符串时a 最妊使用StringBuilder类,其.NET命名空间是System.Text。该类并非创建新的对象,而是 通过Append, Remove, Insert等方法直接对字符串进行操作,通过ToString方法返回操作 结果。 其定义及操作语句如下所示:int num; System.Text.StringBuilder str = new System.Text.StringBuilder(); /创建字符串 str.Append(num.ToString(); /忝加数值 numResponse.Write(str.ToStri

5、ng); /显示操作结果3. 优化 Web 服务器计算机和特定应用程序的配置文件以符合您的特定需要默认情况下,ASP.NET配置被设置成启用最广泛的功能并尽量适应最常见的方案。因此, 应用程序开发人员可以根据应用程序所使用的功能,优化和更改其中的某些配置,以提高应 用程序的性能。下面的列表是您应该考虑的一些选项。仅对需要的应用程序启用身份验证。默认情况下,身份验证模式为Windows,或集成NTLM。R5大多数情况下,对于需要身份 验证的勺一应用一程序,.最好一在一 .Machine-.C-Onfig“文件一中-禁用一身-份验证,并在一.Web.config-文一件中启. 用身份验证。根据适当

6、的请求和响应编码设置来配置应用程序。ASP.NET默认编码格式为 UTF8。如果的应用程序为严格的ASCII,请配置应用程序使用ASCIL以获得稍许的性 能提高。考虑对应用程序禁用 AutoEventWireup。在 Machine.config文件中将 AutoEventWireup属性设置为false,意味着页面不将方法名与 事件进行匹配和将两者挂钩(例如Page_Load)。如果页面开发人员要使用这些事件,需要在 基类中重写这些方法(例如,需要为页面加载事件重写Page.OnLoad,而不是使用Page_Load 方法)。如果禁用 AutoEventWireup, R6页面将通过将事件连

7、接留给页面作者而不是自动执 行它,获得稍许的性能提升。从请求处理管线中移除不用的模块。默认情况下,服务器计算机的Machine.config文件中节点的所有功能均保留为激活。R7根 据应用程序所使用的功能,您可以从请求管线中移除不用的模块以获得稍许的性能提升检 查每个模块及其功能,并按您的需要自定义它。例如,如果您在应用程序中不使用会话状态 和输出缓存,则可以从 列表中移除它们,以便请求在不执行其他有意义的处理时,不必执 行每个模块的进入和离开代码。4. 一定要禁用调试模式R8在部署生产应用程序或进行任何性能测量之前,始终记住禁用调试模式。如果启用了调 试模式,应用程序的性能可能受到非常大的影

8、响。5. 对于广泛依赖外部资源的应用程序,请考虑在多处理器计算机上启用网络园艺ASP.NET 进程模型帮助启用多处理器计算机上的可缩放性,将工作分发给多个进程 (每个 CPU 一个),并且每个进程都将处理器关系设置为其CPU。此技术称为网络园艺。如果应用 程序使用较慢的数据库服务器或调用具有外部依赖项的 COM 对象(这里只是提及两种可 能性),则为您的应用程序启用网络园艺是有益的。但是,在决定启用网络园艺之前,您应 该测试应用程序在网络园中的执行情况。6R9只要可能,就缓存数据和页输出.ASP.NET 提供了一些简单的机制,它们会在不需要为每个页请求动态计算页输出或数据时 缓存这些页输出或数

9、据。另外,通过设计要进行缓存的页和数据请求(特别是在站点中预期 将有较大通讯量的区域),可以优化这些页的性能。与 .NET Framework 的任何 Web 窗体 功能相比,适当地使用缓存可以更好的提高站点的性能,有时这种提高是超数量级的。使用 ASP.NET 缓存机制有两点需要注意。首先,不要缓存太多项。缓存每个项均有开销,特别 是在内存使用方面。不要缓存容易重新计算和很少使用的项。其次,给缓存的项分配的有效 期不要太短。很快到期的项会导致缓存中不必要的周转,并且经常导致更多的代码清除和垃 圾回收工作。若关心此问题,请监视与 ASP.NET Applications 性能对象关联的 Cac

10、he Total Turnover Rate 性能计数器。高周转率可能说明存在问题,特别是当项在到期前被移除时。 这也称作内存压力。7. 选择适合页面或应用程序的数据查看机制根据您选择在 Web 窗体页显示数据的方式,在便利和性能之间常常存在着重要的权衡。例 如,DataGrid Web服务器控件可能是一种显示数据的方便快捷的方法,但就性能而言它的 开销常常是最大的。在某些简单的情况下,您通过生成适当的 HTML 自己呈现数据可能很 有效,但是自定义和浏览器定向会很快抵销所获得的额外功效。Repeater Web服务器控件 是便利和性能的折衷。它高效、可自定义且可编程。8. 将 SqlData

11、Reader 类用于快速只进数据游标SqlDataReader 类提供了一种读取从 SQL Server 数据库检索的只进数据流的方法。如果当 创建 ASP.NET 应用程序时出现允许您使用它的情况,则 SqlDataReader 类提供比 DataSet 类更高的性能。情况之所以这样,是因为SqlDataReader使用SQL Server的本机网络数据 传输格式从数据库连接直接读取数据。另外, SqlDataReader 类实现 IEnumerable 接口,该 接口也允许您将数据绑定到服务器控件。有关更多信息,请参见 SqlDataReader 类。有关 ASP.NET 如何访问数据的信

12、息,请参见通过 ASP.NET 访问数据。9. 将 SQL Server 存储过程用于数据访问在 .NET Framework 提供的所有数据访问方法中,基于 SQL Server 的数据访问是生成高性 能、可缩放 Web 应用程序的推荐选择。使用托管 SQL Server 提供程序时,可通过使用编 译的存储过程而不是特殊查询获得额外的性能提高。10. 避免单线程单元 (STA) COM 组件默认情况下, ASP.NET 不允许任何 STA COM 组件在页面内运行。若要运行它们,必须 在 .aspx 文件内将 ASPCompat=true 属性包含在 Page 指令中。这样就将执行用的线程

13、池切换到 STA 线程池,而且使 HttpContext 和其他内置对象可用于 COM 对象。前者也是 一种性能优化,因为它避免了将多线程单元 (MTA) 封送到 STA 线程的任何调用。使用 STA COM 组件可能大大损害性能,应尽量避免。若必须使用 STA COM 组件,如在任何 interop 方案中,则应在执行期间进行大量调用并在每次调用期间发送尽可能多的信息。另 外,小心不要在构造页面期间创建任何 STA COM 组件。例如下面的代码中,在页面构造 时将实例化由某个线程创建的MySTAComponent,而该线程并不是将运行页面的STA线 程。这可能对性能有不利影响,因为要构造页面

14、就必须完成 MTA 和 STA 线程之间的封送 处理。Dim myComp as new MySTAComponent() Public Sub Page_Load() myComp.Name = Bob End Sub首选机制是推迟对象的创建,直到以后在 STA 线程下执行上述代码,如下面的例子所示。Dim myComp Public Sub Page_Load() myComp = new MySTAComponent() myComp.Name = Bob End Sub推荐的做法是在需要时或者在 Page_Load 方法中构造任何 COM 组件和外部资源。永远不 要将任何 STA CO

15、M 组件存储在可以由构造它的线程以外的其他线程访问的共享资源里。 这类资源包括像缓存和会话状态这样的资源。即使 STA 线程调用 STA COM 组件,也只有 构造此 STA COM 组件的线程能够实际为该调用服务,而这要求封送处理对创建者线程的 调用。此封送处理可能产生重大的性能损失和可伸缩性问题。在这种情况下,请研究一下使 COM 组件成为 MTA COM 组件的可能性,或者更好的办法是迁移代码以使对象成为托管 对象。11. 将调用密集型的 COM 组件迁移到托管代码.NET Framework 提供了一个简单的方法与传统的 COM 组件进行交互。其优点是可以在保 留现有投资的同时利用新的

16、平台。但是在某些情况下,保留旧组件的性能开销使得将组件迁 移到托管代码是值得的。每一情况都是不一样的,决定是否需要迁移组件的最好方法是对 Web 站点运行性能测量。建议您研究一下如何将需要大量调用以进行交互的任何 COM 组 件迁移到托管代码。许多情况下不可能将旧式组件迁移到托管代码,特别是在最初迁移 Web 应用程序时。在这种情况下,最大的性能障碍之一是将数据从非托管环境封送到托管环境。 因此,在交互操作中,请在任何一端执行尽可能多的任务,然后进行一个大调用而不是一系 列小调用。例如,公共语言运行库中的所有字符串都是 Unicode 的,所以应在调用托管代 码之前将组件中的所有字符串转换成 Unicode 格式。另外,一处理完任何 COM 对象或本 机资源就释放它们。这样,其他请求就能够使用它们,并且最大限度地减少了因稍

展开阅读全文
相关资源
相关搜索

当前位置:首页 > 学术论文 > 其它学术论文

电脑版 |金锄头文库版权所有
经营许可证:蜀ICP备13022795号 | 川公网安备 51140202000112号