炫浪网首页 | 加入收藏夹 登录 | 注册
logo
网站导航: 炫浪首页游戏频道女性风采科技学院精品素材桌面壁纸BT影视网络社区健康生活
热门栏目: 炫友贴图编程开发硬件学堂博客空间游戏攻略游戏资源时尚女性美容护肤教程下载
炫浪(科技.学院)
 | 网站首页 | 系统软件 | 图形图像 | 编程开发 | 网络应用 | 硬件学堂 | 办公应用 | 〖图书馆〗 | 
  您现在的位置: 炫浪学院 >> 编程开发 >> 网页制作 >> Asp教程 >> 正文

ASP程序性能测试分析报告详解

炫浪 科技.学院 时间:2007-12-11 16:44:54 来源:炫浪 发表评论 社区讨论

纲要:ASP动态生成的内容以什么方式输出效率最高?最好用哪种方法提取数据库记录集?本文测试了近20个这类ASP开发中常见的问题,测试工具所显示的时间告诉我们:这些通常可以想当然的问题不仅值得关注,而且还有出乎意料的秘密隐藏在内。

  一、测试目的

  本文的第一部分考察了ASP开发中的一些基本问题,给出了一些性能测试结果以帮助读者理解放入页面的代码到底对性能有什么影响。ADO是由Microsoft开发的一个通用、易用的数据库接口,事实证明通过ADO与数据库交互是ASP最重要的应用之一,在第二部分中,我们就来研究这个问题。

  ADO所提供的功能相当广泛,因此准备本文最大的困难在于如何界定问题的范围。考虑到提取大量的数据可能显著地增加Web服务器的负载,所以我们决定这一部分的主要目的是找出什么才是操作ADO记录集的最优配置。然而,即使缩小了问题的范围,我们仍旧面临很大的困难,因为ADO可以有许多种不同的方法来完成同一个任务。例如,记录集不仅可以通过Recordset类提取,而且也可以通过Connection和Command类提取;即使得到记录集对象之后,还有许多可能戏剧性地影响性能的操作方法。然而,与第一部分一样,我们将尽可能地涵盖最广泛的问题。

  具体地讲,这一部分的目标是收集足够多的信息,回答下列问题:

  是否应该通过包含引用ADOVBS.inc?

  使用记录集时是否应该创建单独的连接对象?

  最好用哪种方法提取记录集?

  哪种游标类型和记录锁定方式效率最高?

  是否应该使用本地记录集?

  设置记录集属性用哪种方法最好?

  用哪种方法引用记录集字段值效率最高?

  用临时字符串收集输出是一种好方法吗?

  二、测试环境

  本测试总共用到了21个ASP文件,这些文件可以从本文后面下载。每一个页面设置成可以运行三种不同的查询,分别返回0、25、250个记录。这将帮助我们隔离页面本身的初始化、运行开销与用循环访问记录集的开销。

  为便于测试,数据库连接字符串和SQL命令串都在Global.asa中作为Application变量保存。由于我们的测试数据库是SQL Server 7.0,因此连接串指定OLEDB作为连接提供者,测试数据来自SQL Server的Northwind数据库。SQL SELECT命令从NorthWind Orders表提取7个指定的字段。

< SCRIPT LANGUAGE=VBScript RUNAT=Server >Sub Application_OnStartApplication("Conn") = "Provider=SQLOLEDB; " & _"Server=MyServer; " & _"uid=sa; " & _"pwd=;" & _"DATABASE=northwind"Application("SQL") = "SELECTTOP 0OrderID, " & _"CustomerID, " & _"EmployeeID, " & _"OrderDate, " & _"RequiredDate, " & _"ShippedDate, " & _"Freight " & _"FROM[Orders] "End Sub< /SCRIPT >'alternate sql - 25 recordsApplication("SQL") = "SELECTTOP 25OrderID, " & _"CustomerID, " & _"EmployeeID, " & _"OrderDate, " & _"RequiredDate, " & _"ShippedDate, " & _"Freight " & _"FROM[Orders] "'alternate sql - 250 recordsApplication("SQL") = "SELECTTOP 250 OrderID, " & _"CustomerID, " & _"EmployeeID, " & _"OrderDate, " & _"RequiredDate, " & _"ShippedDate, " & _"Freight " & _"FROM[Orders] "


  测试服务器配置如下:450 Mhz Pentium,512 MB RAM,NT Server 4.0 SP5,MDAC 2.1(数据访问组件),以及5.0版本的Microsoft脚本引擎。SQL Server运行在另外一台具有类似配置的机器上。和第一部分一样,我们仍旧使用Microsoft Web Application Stress Tool 记录从第一个页面请求到从服务器接收到最后一个字节的时间(TTLB,Time To Last Byte),时间以毫秒为单位。测试脚本调用每个页面1300次以上,运行时间约20小时,以下显示的时间是会话的平均TTLB.请记住,和第一部分一样,我们只关心代码的效率,而不是它的可

[1] [2] [3] 下一页

  • 上一篇文章:

  • 下一篇文章: 没有了
  • 发 表 评 论
    姓 名: 主 页:
    评 分: 1分 2分 3分 4分 5分
    内 容:
    频 道 推 荐

    优秀程序员的两大要

    信息时代如何成为一

    如何成为一名C++程序

    Java程序员认证模拟

    高级程序员级考试大

    初级程序员级考试大
    最 新 热 门
    相 关 文 章
    新.Net开发必备工具详解之Snippet 
    在DNN 4.X中自定义登录界面
    .net开发:如何为程式码加上行号
    While deploying... 错误的解决办法
    aspx页面作为模板引擎的一种实现
    字符串和十六进制之间的转换方法
    如何使用ASP.Net加密Cookie
    使用ASP.Net中的自定义控件
    Configuration类在网页实现web.con
    ASP.Net MVC框架配置与分析
    相 关 新 贴
    广 告 展 示

    炫浪网 业务、广告:web#xvna.com (请将#换成@) 业务广告QQ 业务广告QQ2
    Copyright @ 2006-2007 All Right Reserved (主域名 xvna.com 粤ICP备07040110号)
    【声明】本网站部分内容属社区网友发布,本网站仅提供网友交流平台,但有权在本网站范围内引用、发布、转载来自论坛网友发布的内容。网友发布内容纯属个人行为,与本网站立场无关。本网站对于论坛网友发布的内容所引发的版权、署名权的异议及纠纷,不承担任何责任。其他媒体转载须事先与原作者和本网站联系。