视频网站开发方法,营销型网站设计工资,广东省网页制作,在家做衣服的网站1. 数据库访问性能优化 数据库的连接和关闭 访问数据库资源需要创建连接、打开连接和关闭连接几个操作。这些过程需要多次与数据库交换信息以通过身份验证#xff0c;比较耗费服务器资源。ASP.NET中提供了连接池(Connection Pool)改善打开和关闭数据库对性能的影响。系统将用户…1. 数据库访问性能优化 数据库的连接和关闭 访问数据库资源需要创建连接、打开连接和关闭连接几个操作。这些过程需要多次与数据库交换信息以通过身份验证比较耗费服务器资源。ASP.NET中提供了连接池(Connection Pool)改善打开和关闭数据库对性能的影响。系统将用户的数据库连接放在连接池中需要时取出关闭时收回连接等待下一次的连接请求。连接池的大小是有限的如果在连接池达到最大限度后仍要求创建连接必然大大影响性能。因此在建立数据库连接后只有在真正需要操作时才打开连接使用完毕后马上关闭从而尽量减少数据库连接打开的时间避免出现超出连接限制的情况。 使用存储过程 存储过程是存储在服务器上的一组预编译的SQL语句类似于DOS系统中的批处理文件。存储过程具有对数据库立即访问的功能信息处理极为迅速。使用存储过程可以避免对命令的多次编译在执行一次后其执行规划就驻留在高速缓存中以后需要时只需直接调用缓存中的二进制代码即可。另外存储过程在服务器端运行独立于ASP.NET程序便于修改最重要的是它可以减少数据库操作语句在网络中的传输。 优化查询语句 ASP.NET中ADO连接消耗的资源相当大SQL语句运行的时间越长占用系统资源的时间也越长。因此尽量使用优化过的SQL语句以减少执行时间。比如不在查询语句中包含子查询语句充分利用索引等。 2. 字符串操作性能优化 使用值类型的ToString方法 在连接字符串时经常使用号直接将数字添加到字符串中。这种方法虽然简单也可以得到正确结果但是由于涉及到不同的数据类型数字需要通过装箱操作转化为引用类型才可以添加到字符串中。但是装箱操作对性能影响较大因为在进行这类处理时将在托管堆中分配一个新的对象原有的值复制到新创建的对象中。使用值类型的ToString方法可以避免装箱操作从而提高应用程序性能。 运用StringBuilder类 String类对象是不可改变的对于String对象的重新赋值在本质上是重新创建了一个String对象并将新值赋予该对象其方法ToString对性能的提高并非很显著。在处理字符串时最好使用StringBuilder类其.NET 命名空间是System.Text。该类并非创建新的对象而是通过AppendRemoveInsert等方法直接对字符串进行操作通过ToString方法返回操作结果。 其定义及操作语句如下所示 int num; System.Text.StringBuilder str new System.Text.StringBuilder(); //创建字符串 str.Append(num.ToString()); //添加数值num Response.Write(str.ToString); //显示操作结果3. 优化 Web 服务器计算机和特定应用程序的配置文件以符合您的特定需要 默认情况下ASP.NET 配置被设置成启用最广泛的功能并尽量适应最常见的方案。因此应用程序开发人员可以根据应用程序所使用的功能优化和更改其中的某些配置以提高应用程序的性能。下面的列表是您应该考虑的一些选项。 仅对需要的应用程序启用身份验证。 默认情况下身份验证模式为 Windows或集成 NTLM。大多数情况下对于需要身份验证的应用程序最好在 Machine.config 文件中禁用身份验证并在 Web.config 文件中启用身份验证。根据适当的请求和响应编码设置来配置应用程序。ASP.NET 默认编码格式为 UTF-8。如果您的应用程序为严格的 ASCII请配置应用程序使用 ASCII 以获得稍许的性能提高。 考虑对应用程序禁用 AutoEventWireup。 在 Machine.config 文件中将 AutoEventWireup 属性设置为 false意味着页面不将方法名与事件进行匹配和将两者挂钩(例如 Page_Load)。如果页面开发人员要使用这些事件需要在基类中重写这些方法(例如需要为页面加载事件重写 Page.OnLoad而不是使用 Page_Load 方法)。如果禁用 AutoEventWireup页面将通过将事件连接留给页面作者而不是自动执行它获得稍许的性能提升。 从请求处理管线中移除不用的模块。 默认情况下服务器计算机的 Machine.config 文件中 节点的所有功能均保留为激活。根据应用程序所使用的功能您可以从请求管线中移除不用的模块以获得稍许的性能提升。检查每个模块及其功能并按您的需要自定义它。例如如果您在应用程序中不使用会话状态和输出缓存则可以从 列表中移除它们以便请求在不执行其他有意义的处理时不必执行每个模块的进入和离开代码。 4. 一定要禁用调试模式 在部署生产应用程序或进行任何性能测量之前始终记住禁用调试模式。如果启用了调试模式应用程序的性能可能受到非常大的影响。 5. 对于广泛依赖外部资源的应用程序请考虑在多处理器计算机上启用网络园艺 ASP.NET 进程模型帮助启用多处理器计算机上的可缩放性将工作分发给多个进程(每个CPU一个)并且每个进程都将处理器关系设置为其 CPU。此技术称为网络园艺。如果应用程序使用较慢的数据库服务器或调用具有外部依赖项的 COM 对象(这里只是提及两种可能性)则为您的应用程序启用网络园艺是有益的。但是在决定启用网络园艺之前您应该测试应用程序在网络园中的执行情况。 6. 只要可能就缓存数据和页输出 ASP.NET 提供了一些简单的机制它们会在不需要为每个页请求动态计算页输出或数据时缓存这些页输出或数据。另外通过设计要进行缓存的页和数据请求(特别是在站点中预期将有较大通讯量的区域)可以优化这些页的性能。与 .NET Framework 的任何 Web 窗体功能相比适当地使用缓存可以更好的提高站点的性能有时这种提高是超数量级的。使用 ASP.NET 缓存机制有两点需要注意。首先不要缓存太多项。缓存每个项均有开销特别是在内存使用方面。不要缓存容易重新计算和很少使用的项。其次给缓存的项分配的有效期不要太短。很快到期的项会导致缓存中不必要的周转并且经常导致更多的代码清除和垃圾回收工作。若关心此问题请监视与 ASP.NET Applications 性能对象关联的 Cache Total Turnover Rate 性能计数器。高周转率可能说明存在问题特别是当项在到期前被移除时。这也称作内存压力。 7. 选择适合页面或应用程序的数据查看机制 根据您选择在 Web 窗体页显示数据的方式在便利和性能之间常常存在着重要的权衡。例如DataGrid Web 服务器控件可能是一种显示数据的方便快捷的方法但就性能而言它的开销常常是最大的。在某些简单的情况下您通过生成适当的 HTML 自己呈现数据可能很有效但是自定义和浏览器定向会很快抵销所获得的额外功效。Repeater Web 服务器控件是便利和性能的折衷。它高效、可自定义且可编程。 8. 将 SqlDataReader 类用于快速只进数据游标 SqlDataReader 类提供了一种读取从 SQL Server 数据库检索的只进数据流的方法。如果当创建 ASP.NET 应用程序时出现允许您使用它的情况则 SqlDataReader 类提供比 DataSet 类更高的性能。情况之所以这样是因为 SqlDataReader 使用 SQL Server 的本机网络数据传输格式从数据库连接直接读取数据。另外SqlDataReader 类实现 IEnumerable 接口该接口也允许您将数据绑定到服务器控件。有关更多信息请参见 SqlDataReader 类。有关 ASP.NET 如何访问数据的信息请参见通过 ASP.NET 访问数据。 9. 将 SQL Server 存储过程用于数据访问 在 .NET Framework 提供的所有数据访问方法中基于 SQL Server 的数据访问是生成高性能、可缩放 Web 应用程序的推荐选择。使用托管 SQL Server 提供程序时可通过使用编译的存储过程而不是特殊查询获得额外的性能提高。 10. 避免单线程单元 (STA) COM 组件 默认情况下ASP.NET 不允许任何 STA COM 组件在页面内运行。若要运行它们必须在 .aspx 文件内将 ASPCompattrue 属性包含在 Page 指令中。这样就将执行用的线程池切换到 STA 线程池而且使 HttpContext 和其他内置对象可用于 COM 对象。前者也是一种性能优化因为它避免了将多线程单元 (MTA) 封送到 STA 线程的任何调用。使用 STA COM 组件可能大大损害性能应尽量避免。若必须使用 STA COM 组件如在任何 interop 方案中则应在执行期间进行大量调用并在每次调用期间发送尽可能多的信息。另外小心不要在构造页面期间创建任何 STA COM 组件。例如下面的代码中在页面构造时将实例化由某个线程创建的 MySTAComponent而该线程并不是将运行页面的 STA 线程。这可能对性能有不利影响因为要构造页面就必须完成 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 COM 组件存储在可以由构造它的线程以外的其他线程访问的共享资源里。这类资源包括像缓存和会话状态这样的资源。即使 STA 线程调用 STA COM 组件也只有构造此 STA COM 组件的线程能够实际为该调用服务而这要求封送处理对创建者线程的调用。此封送处理可能产生重大的性能损失和可伸缩性问题。在这种情况下请研究一下使 COM 组件成为 MTA COM 组件的可能性或者更好的办法是迁移代码以使对象成为托管对象。转载于:https://www.cnblogs.com/zhengguangITelite/archive/2012/05/16/2504287.html