性能测试-基础知识

性能测试-基础知识

ID:46246524

大小:226.80 KB

页数:54页

时间:2019-11-22

性能测试-基础知识_第1页
性能测试-基础知识_第2页
性能测试-基础知识_第3页
性能测试-基础知识_第4页
性能测试-基础知识_第5页
资源描述:

《性能测试-基础知识》由会员上传分享,免费在线阅读,更多相关内容在工程资料-天天文库

1、0什么是基准测试?基准测试(benchmarking)是一种测量和评估软件性能指标的活动。你口J以在某个吋候通过基准测试建立一个已知的性能水平(称为基准线),当系统的软硕件环境发牛变化之后再进行一次基准测试以确定那些变化对性能的影响。这是基准测试最常见的用途。其他用途包括测定某种负载水平下的性能极限、管理系统或环境的变化、发现可能导致性能问题的条件,等等。基准测试的具体做法是:在系统上运行一系列测试程序并把性能计数器!!!的结果保存起来。这些结构称为“性能指标”。性能指标通常都保存或归档,并在系统环境的描述中进行注解。比如

2、说,有经验的数据库专业人员会把基准测试的结果以及当时的系统配置和环境一起存入他们的档案。这可以让他们对系统过去和现在的性能表现进行对照比较,确认系统或环境的所有变化。基准测试通常都是些功能测试,即测试系统的某个功能是否达到了预期的要求。有些性能测试工具可以对系统几乎所有的方面(从最常见的操作到最复杂的操作,从小负载到中等负载到大负载)进行测试。大部分程序员只在系统发生了奇怪的事情时才考虑进行基准测试,但我认为定期进行基准测试,尤其是在重大事件(比如系统或环境发生变化)Z而和进行基准测试更有意义。一定要首先进行一次基准测试以

3、创建基准线。如果没冇基准线作为参照物,在事件发生之后进行的基准测试是不会对你有多大帮助的。1、优秀基准测试的指导原则在进行基准测试的时候,有许多好的实践方法。在这一节里,我将向大家介绍几个我认为对大家最有帮助的基准测试原则。首先,应该牢记“事前快照”和“事后快照”的概念。不耍等到你对服务器做出修改Z后才想起应该进行一次基准测试并把测试结果与你在六个月前建立的基准线进行对比。六个川的时间会发生许多事情!你应该在做出修改之前进行一次测试,做出修改,然后再对系统进行一次基准测试。这可以让你对三组性能指标进行对比:系统的预期性能、

4、它在修改前的实测性能以及它在修改后的实测性能。你可以发现所发生的事情让你的改变多少会明显一些。比如说,假设你的基准测试冇一项是度量查询时间。你在六个月前为某个特定的测试查询建立的基准线需要花费4.25秒才能完成。现在,你决定修改受测表的某个索引。你在修改之前进行的基准测试得到的结果是15.5秒,而你在修改之后进行的基准测试得到的结果是4.5秒。如果你没有拍摄事前快照,就不会知道你的修改让系统的性能冇了很大的捉高。说不定还会以为你的修改降低了查询的速度-你也许会因此撤消这次修改,结果返回到执行速度慢的查询。虽然这是一个假想的

5、例子,但我希累大家能够从中注意到以下几点。首先,如果你是在对某个系统的数据检索性能执行基准测试,而这个系统的数据量会随着时间的推移而增长,你必须更频繁地运行你的基准测试工具才能准确地把握数据量的增长对系统性能的影响。在刚才的例子里,你应该把冇关性能指标(比如数据负载量)在事丽的测量值当作系统的“止常”指标。其次,必须保证你的测试对你测量的东西冇效。如果你在对某个表的查询性能进行基准测试,你得到的测试结果只限于应用程序级别,不足以从一般意义上预测系统的性能。一定要把应用程序级别的基准与全局性的性能指标区分开来,这样才能保证不

6、会得出错误的结论!!!。另外一个与事丽概念和事后概念有关的好的实践方法是,在活动(负载量相对稳定)的有限时间内尽可能多做几次基准测试,这是为了保证你的测试结果不会受到局部活动(比如临时出现的进程或高资源占用任务)的影响。我发现重复进行儿十次同样的基准测试可以把各次测试结果的平均值作为最终的性能指标值。冇许多技巧可以得到这些统计结果。冇条件的话,你其至可以使用一个统计包或是你喜欢的适用于统计的电了表格应用程序來得出基木的统计数字。注解:冇些基准测试工具冇自己的统计分析包,但MySQLBenchmarkSuite没有。我认为最

7、有用的建议是每次只修改一个地方。一次修改多个地方并不是不可以,但这样你就不能期望从基准测试结果里得出什么冇意义的结论。经常会发生这样的事:你修改了6个地方,其中Z—产生的负面影响掩盖了另外几个的止面效果,剩下的一两个对性能没有任何影响。只冇每次修改一个地方,你才能准确地判断出它对系统性能的影响是负面的、正面的述是没有影响。(控制变量法)还有,只要有可能,就应该使用实际数据来进行基准测试。人工牛成的测试数据怎么说也会冇一些规律可循,那样得到的测试结果往往不能反映实际情况,某些特定的功能(比如边界值和范围检查等)可能永远也得不

8、到测试。如果你的数据变化很频繁,你应该选择某个吋刻为它们“拍摄”一张快照,然后使用这张快照来进行每一次测试。不过,这么做虽然能够保证使用真实的数据来测试性能,可是随着数据量的增长也许无法测试出系统性能的下降。最后,在解读基准测试结杲和管理预期目标时,一定要让你的FI标有现实意义。如果你想改善系统在某种特

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。