衡量我们架构的数据库的优劣——谈数据库性能测试

发表于:2010-3-23 13:27

字体: | 上一篇 | 下一篇 | 我要投稿

 作者:三十而立(CSDNBlog)    来源:51Testing软件测试网采编

  在做体系规划的时候,我们需要根据我们的体系的业务量的需求,对我们的数据库进行选型,一个系统的运行速度和稳定性的保障,不仅仅是网络上要去考虑的,作为底层的提供数据存储应用的数据库服务器的性能的好坏和稳定性,对我们系统的整体都有着至关重大的影响。那么我们在考量我们的数据库的优劣,以及我们对数据库服务器规划的好坏该怎么样来进行测试呢。

  这里我将基于自己多年应用开发和数据库管理的经验上,来谈谈自己的关于数据库性能测试的看法。

  Os的性能考虑

  作为Oracle数据库,个人感觉在Linux上的性能远远优于Window,所以我选择Oracle的时候多少在Linux上的选择,为了在内存能够有更大的扩充性,选择64bit的,这样Oracle也是64bit的。这样的话,我们在做性能测试的时候,需要对我们的Os也进行多方面的监控,CPU,Memory,以及IO stat,有时也可以把network做进去,虽然我们现在的应用在这方面没有大多的约束,不过能够做还是可以带进去做的。用LoadRunner基本上可以做的到了。

  最大连接数的考虑

  在Java的很多程序里使用了连接池,这样的概念,所以往往忽略了这方面的考虑,我们的系统需要大的访问量的时候,连接池也是要跟着扩大的,如果操过了一定的连接,是不是会导致我们的数据库的性能下降的非常的严重叻,这是我们也需要考虑大的因素,所以我们需要通过增量的方式,看看架构好的数据库系统在连接数线性增加的过程中,其性能是不是也是符合我们预期的叻。

  数据量的考虑

  不同的数据量,数据库对相同的sql是有不一样的响应的,在Oracle数据库本质上,不同的数据量(有时相同的数据量,没有做statistics)同一个sql的执行计划都是有可能有非常大的差异的,那么我们的数据库在数据量的不同级别上,表现是不是没有太大的相差叻。同时,我们需要根据我们的测试有个以后数据量影响范围上的一个考虑。

  数据库并发和事务的考虑

  数据库的并发对数据库的访问也是有很大影响的,那么我们数据库体系在并发的线性的测试因素下又是如何变化的叻,这时一个我们需要关注的一点,同时,我们需要测试到大批量的事务处理上,数据库服务器是不是有足够的响应时间。同样的通过不同的测试因子,来进行对其的研究。

  当然篇幅有限,测试方法论是一个很细化和值得深入研究的工程方法。这里我只是概要性的进行了自己的分析,以前在带项目的过程中,也和我们的自动化测试的人员进行过一起的讨论。也都是从上面的考虑点,进行我们的测试用例的设计和实现的,不过loadrunner对Oracle的支持还是做的很不错的,大致的一些report直接在loadrunner里可以找到,当然是没有Oracle自己的详细的,不过作为性能的测试,这里不会深入到数据库的体系里,所以我们这时是没有必要用statspack这样的分析工具的,主要还是在监控方面就可以叻。这里推荐一下quest的产品spotlight,这个做性能监控也非常的不错,不过就是要额外的银子叻。

《2023软件测试行业现状调查报告》独家发布~

关注51Testing

联系我们

快捷面板 站点地图 联系我们 广告服务 关于我们 站长统计 发展历程

法律顾问:上海兰迪律师事务所 项棋律师
版权所有 上海博为峰软件技术股份有限公司 Copyright©51testing.com 2003-2024
投诉及意见反馈:webmaster@51testing.com; 业务联系:service@51testing.com 021-64471599-8017

沪ICP备05003035号

沪公网安备 31010102002173号