压力测试实例WAS_第1页
压力测试实例WAS_第2页
压力测试实例WAS_第3页
压力测试实例WAS_第4页
压力测试实例WAS_第5页
已阅读5页,还剩6页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

1、利用现代的设计技术和正式的技术复审可以减少代码中存在的初始错误,但是错误总是存在的,如果开发者找不到错误,那么,客户就会找到它们。越来越多的软件组织认识到软件测试是软件质量保证的重要元素之一,很多软件开发组织将30%40%甚至更多的项目资源用在测试上,软件测试技术和软件测试策略受到了高度的重视和广泛的应用。本文不想就软件测试技术和软件测试策略作深入的理论分析,而是列举一个在软件系统测试阶段进行的压力测试实例,希望能通过这个实例与从事软件测试相关工作的朋友进行交流。首先介绍一下实例中软件的项目背景,该软件是一个典型的三层C/S架构的MIS系统(客户端/应用服务器/数据库管),中间层是业务逻辑层,

2、应用服务器处理所有的业务逻辑,但应用服务器本身不提供负载均衡的能力,而是利用开发工具提供的ORB(对象请求代理)软件保证多个应用服务器间的负载均衡。本次测试的目的是:进行单个应用服务器的压力测试,找出单个应用服务器能够支持的最大客户端数。测试压力估算的依据是:假定在实际环中,用户只启用一个应用服务器进行所有的业务处理。方法是:按照正常业务压力估算值白1110倍进行测试,考察应用服务器的运行情况。压力测试的详细计划如下:压力测试计划1、测试计划名称河北省公安交通管理信息系统压力测试计划。2、测试内容2.1 背景本次测试中的压力测试是指模拟实际应用的软硬件环境及用户使用过程的系统负荷,长时间运行测

3、试软件来测试被测系统的可靠性,同时还要测试被测系统的响应时间。用户的实际使用环境:4 由两台旧MXSeries250PCServer组成的MicrosoftCluster;5 数据库管理系统采用Oracle8.1.6;应用服务器程序和数据库管理系统同时运行在MicrosoftCluster上。6 有200个用户使用客户端软件进行业务处理,每年通过软件进行处理的总业务量为:150万笔业务/年。应用服务器的压力测试;2.3不被测试的特性系统的客户端应用程序的内部功能;数据库中的数据量对程序性能的影响。3、测试计划1 测试强度估算测试压力估算时采用如下原则:全年的业务量集中在8个月完成,每个月20个

4、工作日,每个工作日8个小时;采用8020原理,每个工作日中80%的业务在20%的时间内完成,即每天80%的业务在1.6小时内完成;测试压力的估算结果:去年全年处理业务约100万笔,其中15%的业务处理每笔业务需对应用服务器提交7次请求;70%的业务处理每笔业务需对应用服务器提交5次请求;其余15%的业务每笔业务向应用服务器提交3次请求。根据以往统计结果,每年的业务增量为15%,考虑到今后三年业务发展的需要,测试需按现有业务量的2倍进行。每年总的请求数量为:(100*15%*7+100*70%*5+100*15%*3)*2=300万次/年。每天的请求数量为:300/160=1.875万次/天。每

5、秒的请求数量为:(18750*80%)/(8*20%*3600)=2.60次/秒。正常情况下,应用服务器处理请求的能力应达到:3次/秒。1 测试环境准备1.4 基本硬件及软件环境的准备1)网络环境:公司内部的以太网,与服务器的连接速率为100M,与客户端的连接速率为10/100M自适应。2)使用两台旧MXSeries250(1G内存)PCServer#MicrosoftCluster,安装系统软件Windows2000AdvanceServer及MicrosoftClusterServer(MSCS)。3)数据库管理系统的安装及配置:在测试用的旧MXSeries服务器上安装Oracle8.1.

6、6,数据库采用OracleFailSafe(ofs)的Active/Passive配置。安装数据库管理系统及支撑软件(包括VisiBroker和BDEAdministrator)。4)安装被测的应用服务器程序。5)客户端的PC机:10台(PID600/128MRAM)。1.4 系统客户端测试程序的编写系统客户端测试程序使用Delphi编写,要求测试程序实现如下功能:1)模拟一个主要的向应用服务器发送请求并接收响应信息的功能。要求交替模拟两种情况:第一种,发送的请求至少包括10个参数,参数类型涵盖字符、日期、数字种类型;接收的响应信息不少于1个参数;第二种,发送的请求不少于1个参数;接收的响应信

7、息至少包括10个参数,参数类型涵盖字符、日期、数字种类型。2)必须能够通过参数设定在每台PC机上运行的客户端测试程序个数、请求的时间间隔(单位:毫秒)、运行时间(单位:小时)。3)在数据库中建立测试记录表,生成测试记录,向数据库写入测试记录的功能不通过被测的应用服务器实现。日志内容包括:发送测试请求的机器名、客户端测试程序序号、发出请求时间、收到响应时间、处理是否成功。表名:TEST_LOG,字段名:MACHINE、ID、START_TIME、END_TIME、FLAG。1.4 系统本底数据的准备为考察系统运行一段时间后系统的响应性能,参照实际运行情况及发展进行系统的本底数据准备。业务处理中涉

8、及到的业务表中都要求按设计规模进行本底数据的准备。要求准备的数据记录的有效性符合系统要求,数据有效性的具体要求参见数据库设计及系统设计文档。1 破坏性测试按照设计连接的客户端连接数量进行测试,把应用服务器处理请求的设计频度增加1-10倍,分别测试出现错误的状态和和出现错误的比率,考察是否出现不可恢复错误,系统设计要考虑出现严重错误情况下负荷减轻错误自动恢复的实现方法。计划时间:2天;这个时间包括破坏性的修复和自动恢复的实现需要的时间。在测试过程中每10分钟记录一次旧MXseriesPCServer的内存及CPU使用情况,包括被测程序的内存占用百分比、数据库管理系统的内存占用百分比、操作系统的内

9、存占用百分比。选择一种负荷比设计负荷重的情况(应用服务器处理请求的频度为应用服务器处理请求的设计频度的1.5倍),进行24小时稳定性测试。测试方法和工具黑盒测试测试工具:无外购的测试工具,自己编制的测试工具。测试时间计划环境准备:2天。其中:基本硬件、软件环境及系统本底数据的准备:1天,系统客户端测试程序的编写及测试:1天。破环性测试:2天。强度稳定性测试:1天。测试中的问题及处理暂停标准和再启动要求暂停标准:被测试软件在强度稳定性测试中频繁出现异常(每小时出现1次以上)时。用户或公司要求暂停测试时。再启动要求:通过调试后,预计被测试软件的可靠性有所提高时,可再次启动测试。不可预见问题不可预见

10、问题包括:测试环境被破坏而导致测试无法进行;当出现上述不可预见问题时,测试终止,就已完成的测试内容编制测试总结报告,并在报告中说明测试终止的原因。测试报告2002.06.21测试总结报告提交日期:2002.06.21。应生成的测试文件测试记录(测试负责人和参与测试的人员签字);测试总结报告。测试总结报告中必须包含的内容被测试软件名称、测试项、测试环境;被测试软件的压力测试结论:响应时间、最大/最小并发数、失败的次数、正常连续运行的最长/最短时间,并发数与失败的关系。4、人员和职责职责测试工程师:负责编写测试计划,组织测试,对测试过程进行记录,收集、整理测试记录数据,对测试结果进行分析,编写测试

11、总结报告。软件工程师:负责编写、调试客户端测试软件;数据库管理系统的安装、ofs配置及系统的本底数据准备。系统工程师:负责测试用的硬件维护及操作系统安装、MSCS配置。总工程师:负责对测试计划及测试总结报告进行批准。用户:必要时可参加测试,并提出具体的测试要求;可要求暂停测试。人员和训练要求本次测试无特别的人员及培训要求。5、批准本测试计划必须经过总工程师批准后才能开始实施。交通管理信息系统压力测试实例本文将列举一个在软件系统测试阶段进行的压力测试实例,希望能通过这个实例与从事软件测试相关工作的朋友进行交流。首先介绍一下实例中软件的项目背景,该软件是一个典型的三层C/S架构的MIS系统(客户端

12、/应用服务器/数据库管),中间层是业务逻辑层,应用服务器处理所有的业务逻辑,但应用服务器本身不提供负载均衡的能力,而是利用开发工具提供的ORB(对象请求代理)软件保证多个应用服务器间的负载均衡。本次测试的目的是:进行单个应用服务器的压力测试,找出单个应用服务器能够支持的最大客户端数。测试压力估算的依据是:假定在实际环中,用户只启用一个应用服务器进行所有的业务处理。方法是:按照正常业务压力估算值的110倍进行测试,考察应用服务器的运行情况。压力测试的详细计划如下:压力测试计划1、测试计划名称河北省公安交通管理信息系统压力测试计划。2、测试内容本次测试中的压力测试是指模拟实际应用的软硬件环境及用户

13、使用过程的系统负荷,长时间运行测试软件来测试被测系统的可靠性,同时还要测试被测系统的响应时问。用户的实际使用环境:由两台旧MXSeries250PCServer组成的MicrosoftCluster;数据库管理系统采用Oracle8.1.6;应用服务器程序和数据库管理系统同时运行在MicrosoftCluster上。有200个用户使用客户端软件进行业务处理,每年通过软件进行处理的总业务量为:150万笔业务/年。2.2测试项应用服务器的压力测试;2.3不被测试的特性系统的客户端应用程序的内部功能;数据库中的数据量对程序性能的影响。3、测试计划测试强度估算测试压力估算时采用如下原则:全年的业务量集

14、中在8个月完成,每个月20个工作日,每个工作日8个小时;采用8020原理,每个工作日中80%勺业务在20%勺时间内完成,即每天80%勺业务在1.6小时内完成;测试压力的估算结果:去年全年处理业务约100万笔,其中15%勺业务处理每笔业务需对应用服务器提交7次请求;70%勺业务处理每笔业务需对应用服务器提交5次请求;其余15%的业务每笔业务向应用服务器提交3次请求。根据以往统计结果,每年的业务增量为15%考虑到今后三年业务发展的需要,测试需按现有业务量的2倍进行。每年总的请求数量为:(100*15%*7+100*70%*5+100*15%*3*2=300万次/年。每天的请求数量为:300/160

15、=1.875万次/天。每秒的请求数量为:(18750*80%/(8*20%*3600)=2.60次/秒。正常情况下,应用服务器处理请求的能力应达到:3次/秒。测试环境准备基本硬件及软件环境的准备1)网络环境:公司内部的以太网,与服务器的连接速率为100M与客户端的连接速率为10/100M自适应。2)使用两台IBMXSeries250(1G内存)PCServer#MicrosoftCluster,安装系统软件Windows2000AdvanceServer及MicrosoftClusterServer(MSCS。3)数据库管理系统的安装及配置:在测试用的旧MXSeries服务器上安装Oracle

16、8.1.6,数据库采用OracleFailSafe(ofs)的Active/Passive配置。安装数据库管理系统及支撑软件(包括VisiBroker和BDEAdministrator)。4)安装被测的应用服务器程序。5)客户端的PC机:10台(PIH600/128MRAM。系统客户端测试程序的编写系统客户端测试程序使用Delphi编写,要求测试程序实现如下功能:1)模拟一个主要的向应用服务器发送请求并接收响应信息的功能。要求交替模拟两种情况:第一种,发送的请求至少包括10个参数,参数类型涵盖字符、日期、数字种类型;接收的响应信息不少于1个参数;第二种,发送的请求不少于1个参数;接收的响应信息

17、至少包括10个参数,参数类型涵盖字符、日期、数字种类型。2)必须能够通过参数设定在每台PC上运行的客户端测试程序个数、请求的时间问隔(单位:毫秒)、运行时间(单位:小时)。3)在数据库中建立测试记录表,生成测试记录,向数据库写入测试记录的功能不通过被测的应用服务器实现。日志内容包括:发送测试请求的机器名、客户端测试程序序号、发出请求时间、收到响应时间、处理是否成功。表名:TEST_LOG字段名:MACHINEID、START_TIMEEND_TIMEFLAG系统本底数据的准备为考察系统运行一段时间后系统的响应性能,参照实际运行情况及发展进行系统的本底数据准备。业务处理中涉及到的业务表中都要求按

18、设计规模进行本底数据的准备。要求准备的数据记录的有效性符合系统要求,数据有效性的具体要求参见数据库设计及系统设计文档。破坏性测试按照设计连接的客户端连接数量进行测试,把应用服务器处理请求的设计频度增加110倍,分别测试出现错误的状态和和出现错误的比率,考察是否出现不可恢复错误,系统设计要考虑出现严重错误情况下负荷减轻错误自动恢复的实现方法。计划时间:2天;这个时间包括破坏性的修复和自动恢复的实现需要的时间。在测试过程中每10分钟记录一次旧MXseriesPCServer的内存及CPUS用情况,包括被测程序的内存占用百分比、数据库管理系统的内存占用百分比、操作系统的内存占用百分比。强度稳定性测试选择一种负荷比设计负荷重的情况(应用服务器处理请求的频度为应用服务器处理请求的设计频度的1.5倍),进行24小时稳定性测试。测试方法和工具黑盒测试测试工具:无外购的测试工具,自己编制的测试工具。测试时间计划环境准备:2天。其中:基本硬件、软件环境及系统本底数据的准备:1天,系统客户端测试程序的编写及测试:1天。破环性测试:2

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论