科技行者

行者学院 转型私董会 科技行者专题报道 网红大战科技行者

知识库

知识库 安全导航

至顶网软件频道基础软件用VS.NET中的测试工具测试ASP.NET程序

用VS.NET中的测试工具测试ASP.NET程序

  • 扫一扫
    分享文章到微信

  • 扫一扫
    关注官方公众号
    至顶头条

在编写ASP.NET应用程序的时候,你会花费多长的时间来考虑性能的问题?很不幸,大多数开发者都对性能问题感到很后悔

作者:陶刚 来源:天极网 2007年11月7日

关键字: Windows

  • 评论
  • 分享微博
  • 分享邮件
运行测试并建立基线

  要运行刚才建立的测试,只需要简单地右键点击该测试并选择"开始测试"。测试开始以后,点击"显示详细信息"按钮。细节框中将显示正在运行的测试的一个图表,同时显示在运行测试过程中可能出现的任何错误(图5所示)。第一次运行这个测试建立了基线,我们可以把它与当前的和未来的性能进行对比。图4显示的基线是每秒大约90个请求。


图4:基线图表

  现在你拥有了一个确定的基线了,你可以对应用程序作一些修改以测量修改所引起的性能提升或降低。的确,我使用的测试示例极其简单,但是我会显示出对这一小段代码进行少量的修改可能对应用程序的性能产生很大的影响。

  了解改善的部分

  评估的方面越多,改善的机会就越大。在例子中我将对应用程序作一些小的修改,并在每个修改之后进行评估。尽管在现实情况下你不可能每步修改都进行这样的测试,但是你应该有周期性检查性能的习惯。对于我们公司的Community Server产品,我们拥有一套用于评估总体应用程序开销的基线。如果进行了重大的修改,开发者就可以使用前面的测试数据来研究性能的提升或降低。

  我对示例应用程序的第一处修改是改变返回数据量的限制。我把SQL查询SELECT * FROM Products改变为SELECT TOP 25 * FROM Products。这好像只是对代码进行了微小的修改。毕竟我只是限制屏幕中输出的数据量,但是其结果却是惊人的。其性能从每秒90个请求上升到200以上--性能提高了100%以上。由于你拥有基线,你知道了限制绑定到数据表格的数据量一定会影响性能。我还要修改其它一些东西。

  下一步,修改<asp:DataGrid/>服务器控件,添加EnableViewState="false":

<asp:DataGrid EnableViewState="false" id="DataGrid1" runat="server" />

  ViewState是ASP.NET的一个重要的特性,但是并非总是需要的。实际上,大多数使用了ViewState的数据表格都是不需要它的。在例子中,通过禁止ViewState,我可以提高166%的性能。我们继续!

  下一步,添加下面的代码以激活输出缓冲(OutputCaching):

<%@ OutputCache Duration="60" VaryByParam="none" %>


图5:输出缓冲

  现在重新运行该测试。太惊人了!性能提高了600%,如图5所示。你可以调整OutputCache的持续数值,例如把OutputCache的持续值设置为1秒--你可以看到性能再次有很大的变化。

  建立测试环境

  测试操作是CPU密集型的事务,因此在运行测试的时候,你可能看到CPU的占用率接近100%。它在与测试部件分享CPU时间的时候会拿走正在测试的应用程序的资源。所有的配置选项都会影响测试结果,其中一部分模拟现实世界要真实一些。例如,如果SQL Server和ASP.NET在同一台计算机上,就无法模拟网络I/O的开销。大多数应用程序使用的数据库都不在Web服务器上。

  为了建立真实的测试环境,把大量的旧的用于开发的计算机作为客户端使用。不要使用虚拟机。在这些计算机上运行Application Center Test。下一步尽可能地模拟现实世界。在一个没有运行其它任何应用程序的服务器操作系统上运行该Web应用程序,并且连接到另一台服务器的数据库。

  需要说明的是,在开发环境中运行"烟幕"测试也没有什么错误。烟幕测试不能模拟现实世界,但是仍然可以提供大量的有价值的数据,并且可以用于预计在现实世界中同样的测试产生的结果。

  后续的步骤和测试覆盖

  现在你对如何测试和评估有了一些了解了,我推荐你在自己的应用程序上使用Application Center Test。了解你的用户在典型情况下如何使用应用程序是有好处的:哪些页面执行得更好,哪些页面没有改善?

  例如,在Community Server中我们运行了多种类型的性能测试。主线(Mainline)测试包含了匿名和验证的情况。在大量个性化的应用程序中这一点可能显著的改变性能情况。

  主线测试还包含了贯穿系统的通用路径,例如网络日志、图表、论坛的主视图,以及每个屏幕的不同视图。很明显,这些主线情形良好的执行情况是非常重要的,最好在这儿花费大量的时间以确保其正确性。

  如果你管理或运行那些必须支持两个或多个并发用户的项目,并且你不知道自己的主页面每秒钟可以处理多少个请求,那么就遇到问题了。

  如果你拥有性能测试脚本,那么在每次重要的修改之后都应该进行评估。如果实际上是你自己构造的代码,那么就可以经常深入源代码并且评价各部分和重新编译。这可以帮助你检查出问题在于程序编写得不好还是其它的原因。其它的原因有90%都出在数据访问代码部分。
你还可以测试应用程序中的通用路径。记录测试的时候,只需要输入用户可能使用的通用导航路径。Application Center Test将记录下这些信息,并且你可以重新播放准确的脚本。如果你喜欢,可以编辑生成的VBScript文件,给你的测试脚本引入延迟或其它有意义的输入信息。

  我推荐的最后的测试需要做很多工作。例如,在Community Server中我们的开发者希望测试应用程序可以每分钟可以支持多少个post(张贴)操作。为了测试它,我们不是把内容写入窗体,而是建立一个新ASP.NET页面,它使用API来输入内容。接着这个页面在Application Center Test中运行,应用程序支持的每秒钟张贴操作的数量就产生了。换句话说,有时候为了测试所有的情形,你可能需要多做一些工作。

  结论

  我没有解释Application Center Test提供的所有信息,但是我希望本文给了你足够的使用Application Center Test的知识,这样你才能够使用它来评估和改善自己的应用程序。请记住,建立基线、频繁的评估(至少在每次重大的修改之后)并识别出关键的部分。遵循这些简单的规则,你会对应用程序有更好的理解,并且很有希望找到提高性能的机会。

查看本文来源

    • 评论
    • 分享微博
    • 分享邮件
    邮件订阅

    如果您非常迫切的想了解IT领域最新产品与技术信息,那么订阅至顶网技术邮件将是您的最佳途径之一。

    重磅专题
    往期文章
    最新文章