最新性能测试报告案例.docx
- 文档编号:4195420
- 上传时间:2022-11-28
- 格式:DOCX
- 页数:23
- 大小:263.86KB
最新性能测试报告案例.docx
《最新性能测试报告案例.docx》由会员分享,可在线阅读,更多相关《最新性能测试报告案例.docx(23页珍藏版)》请在冰豆网上搜索。
最新性能测试报告案例
密级:
秘密
****
公司****
管理系统
性能测试分析报告
(V2.0)
北京***软件技术开发有限公司
2008年12月01日
精品文档
标题
****公司****管理系统性能测试分析报告
创建日期
2008-12-01
打印日期
文件名
存放目录
所有者
作者
张三
修订记录
日期
描述
作者
对结论进行细化
李四
文档审核/审批
此文档需如下审核。
姓名
职务/职称
签名
签名日期
1测试背景1
1.1测试目标1
1.2测试时间1
1.3测试地点1
1.4测试人员1
2测试方法简介1
3测试环境3
3.1被测系统3
3.1.1硬件环境3
3.1.2数据库环境4
3.1.3软件环境4
3.2测试系统4
3.2.1测试环境搭建4
3.2.2测试软件4
4测试设计5
4.1模拟用户数5
4.2测试模型建立5
5测试结果分析6
5.1业务场景一(无基础数据)梯度压力测试分析6
5.1.1平均响应时间梯度对比6
5.1.2系统资源利用率7
5.1.3系统处理能力8
5.2业务场景一对比测试分析8
5.2.1平均响应时间对比8
5.2.2处理能力对比9
5.2.3资源利用率对比图9
5.3系统稳定性测试10
5.4有、无合同场景对比测试11
5.4.1响应时间分析11
5.4.2处理能力对比图12
5.4.3资源利用率对比图13
5.5业务场景二调优对比测试13
5.5.1第一次调优14
5.5.2第二次调优15
5.5.3第三次调优16
6测试结论17
6.1业务场景一(无合同)17
6.2业务场景二(有合同)17
6.3稳定性18
7调优建议18
8签字确认19
1测试背景
1.1测试目标
对****公司****管理系统的开具发票功能进行性能测试,客观、公正评估系统的性能现
状。
1、开发正确、有效的性能测试脚本,模拟企业用户开具发票操作行为,作为测试有效实施的基础;
2、通过性能测试,客观、公正评估在当前测试环境下,被测系统的各项性能指标表现;
3、验证被测系统的业务处理能力是否能够满足在业务高峰期的性能要求,为被测系统上线提供参考依据。
如不满足,对性能瓶颈进行定位分析,提供性能调优建议。
1.2测试时间
测试自2008年11月20日启动,至12月01日测试执行结束。
1.3测试地点
**大厦*座**层
1.4测试人员
单位
姓名
备注
****公司
***
***
***
***
北京###公司
***
2测试方法简介
压力测试采用业界成熟的自动化性能测试工具,通过创建压力测试程序、构建压力测试
模型,对被测试系统实施自动化压力测试,最后形成压力测试结果分析报告。
1)压力测试实施模型:
通过自动化测试工具模拟最终用户向服务器发起业务请求,进行性能测试。
通过测试工
精品文档
具对测试过程中系统各点进行监控
告供分析使用
被测系统
I
性能监控器
虚拟用户生成器
控制器
测试环境准备
系统性能压力测试环境要求与生产系统的软
硬件环境保持
并具有相同规模的业
压力模型定义
用例选取是性
典型的交易和业务流程
1)
用户操作使用频繁
2)
对系统性能影响较大
3)
性能测试压力符合业务系统实际的实际交易发生比例
4)
循环
测试数据准备
测试数据要求尽量模拟真实业务数据
精品文档
Web
服务器
2.模拟大量的真实用户生成压力
3.监控器实时捕获系统的性能状态
2)压力测试实施基本流程
间隔,并发间隔,用户加载和减压时间根据系统基准测试结果进行判断和设置。
每一次测试结束后工具自动采集测试结果并生成原始报
务数据,并保证软件版本与生产环境保持
能测试压力模型设计的首要任务。
用例选取的原则是
1.Controller起到调度压力测试并管理监控器
实际执行场景的设置尽量模拟实际业务进行,运行时长,操作间隔(思考时间)
而且具有一定可重用性。
能贯穿各相关系统,保
应用服务器数据库服务器
此次性能测试的用例选择,按照海泰方圆提供的业务数据进行分析抽取
4.测试结果被搜集及保存起来供分析
5.产生性能分析报告
证业务流程的顺畅正确。
具体的数据类型和数据量需要根据选择的交易类别或性能测试场景设置而定。
此外性能测试会产生大量的虚拟用户,需要消耗大量的测试数据。
其数量直接关乎测试
结果。
测试中所需的基本数据类型为:
系统用户数据:
登陆系统使用的用户名-口令等,数量与虚拟用户数一致。
业务数据:
每个虚拟用户模拟真实用户进行操作时使用到的数据。
辅助数据:
为保证业务操作的正常进行而设置的基本信息资料。
测试程序开发:
利用在历史数据收集步骤中所获得的典型用户的系统访问模式,做为测试程序开发的依
据。
该测试程序应该覆盖典型用户的系统访问模式所涉及的操作。
脚本的开发是利用
LoadRunnerVugen进行脚本录制,开发,参数化,调试的过程。
测试执行:
测试准备阶段完毕后,确保测试环境、测试程序、测试过程、测试数据,且均已验证通过后,然后在指定的时间内可对系统施实性能测试,性能测试执行分为两个阶段:
1、性能基准测试:
系统在轻负载环境下,模拟各业务的单用户交易,评估当前系统的性能表现,并作为后续压力测试的性能比较基准;
2、单交易负载测试:
3、负载压力测试:
仿真现实,模拟大批量并发业务交易,评估系统在高负载情况下系
统的性能表现。
测试结果分析报告:
压力测试结果经过确认有效后,将汇总压力测试结果,形成最终的性能测试分析报告。
3测试环境
3.1被测系统
3.1.1硬件环境
系统
IP地址
所在主机配置
备注
应用服务器
192.168.3.13
CPUXeonMPX46002.6GHz
Win2003Server
内存
硬盘
8G
200G7200转
192.168.3.15
CPU
XeonMPX46002.6GHz
Win2003Server
数据库服务器
内存
8G
硬盘
500G7200转
3.1.2数据库环境
使用生成的6800万条数据。
3.1.3软件环境
类型
应用及版本号
备注
应用服务器
Weblogic8.1
数据库
Oracle9i
3.2测试系统
3.2.1测试环境搭建
测试机配置:
类型
数量(台)
IP
配置
备注
控制台
1
192.168.3.129
IntelE46002.4GHz
Win2003Server
内存2G/硬盘400G7200转
负载发
9
192.168.3.130~
IntelE46002.4GHz
Win2003Server
生器
192.168.3.138
内存1G/硬盘400G7200转
3.2.2测试软件
采用MercuryInteractive公司的LoadRunner测试及分析软件作为测试工具。
LoadRunner简介:
LoadRunner是一种预测系统行为和性能的工业标准级负载测试工具。
在LoadRunner的
帮助下,用户可以以模拟上千万用户实施并发负载及实时性能监测的方式来确认和查找问题。
LoadRunner能够对整个企业架构进行测试,它通过模拟实际用户的操作行为和实行实时性能监测,来帮助用户更快的查找和发现问题。
此外,LoadRunner能支持广泛的协议和
技术,可以为用户的特殊环境提供特殊的解决方案。
本次测试采用的LoadRunner版本为9.0。
4测试设计
4.1模拟用户数
依据系统目前的业务量以及未来业务量增长,对当前系统分别按3000、4500、6000用
户进行压力测试,以评估系统在不同压力梯度情况下的性能表现。
4.2测试模型建立
此次性能测试的业务选择,应覆盖各性能关键业务,并通过海泰方圆、北京行所志双方
协商选取被测业务。
根据协商选定如下业务进行性能测试:
开具发票
以此基础上定义测试执行压力模型:
在混合业务场景压力梯度测试过程中,分别按3000、4500、6000用户进行压力测试,
在各个压力测试过程中保持测试场景和调度测试的完全一致,使结果具有很好的可比性。
压力测试执行场景描述如下:
1、模拟用户数:
3000、4500、6000
2、Pacing:
120秒;
3、当所有用户加载完毕后连续运行15分钟;
4、用户调度策略:
每1秒启动30个虚拟用户。
业务场景
序号
交易
业务
配比
执行时间
操作间隔
1
开具发票
100%
15分钟
120秒
业务场景二
序号
交易
业务
配比
执行时间
操作间隔
1
开具发票(无合同)
85%
15分钟
120秒
2
开具发票(有合同)
15%
说明:
按照以上场景设置,可估算出模拟用户数与每小时业务量的对应关系如下:
模拟用户数
3000
4500
6000
每小时业务量
90000
135000
180000
5测试结果分析
说明:
术语解释
(事务)—LoadRunner中定义,为一个流程中某个环节的称谓,一个流程可称为一个大的事务,在这个大的交易中包含许多的小的事务。
响应时间一LoadRunner中衡量流程中各个事务性能的最佳手段,计算的是端到端
的时间,说的通俗一点,从点击应用中的某个控件,到从数据库返回数据到客户端,
整个过程都被计算在事务的响应时间内。
场景—LoadRunner中专门术语。
它是所有测试资源包括测试脚本、运行设置、运行用户数等的集合。
在这个场景中,可以定义并发用户的数目,定义要运行的脚本,或者说运行的流程类型。
在一个场景中,可以是单个流程,也可以是多个流程的混合。
虚拟用户一LoadRunner中特定术语,为模拟现实中的实际用户,测试软件使用虚拟用户代替真实的用户。
5.1业务场景一(无基础数据)梯度压力测试分析
5.1.1平均响应时间梯度对比
下图是不同用户数下各事务的平均响应时间随用户数变化的曲线:
一登录
开具发票
*—录入并开具
事务
3000用户
4500用户
6000用户
登录
0.56
1.312
2.14
开具发票
0.24
0.87
2.08
录入并开具
0.43
1.098
2.70
平均响应时间分析:
从上图中可以看出,各操作的响应时间随着用户数的增加呈上升趋势,但都没有超过5
秒,在可接受范围内。
5.1.2系统资源利用率
cpu利用率(%
*cpu利用率(%
CPU利用率分析:
在上图中我们可以看出3000用户、4500用户及6000用户时,CPU利用率均在正常范围内,系统表现良好。
5.1.3系统处理能力
TPS
系统处理能力分析:
可以看出,在无基础数据的情况下,系统处理能力随用户数的增加呈线性上升趋势,即
系统无性能瓶颈,6000用户时系统处理能力达到每小时173880笔,满足并超出客户提出的
4小时20万张发票的处理能力。
5.2业务场景一对比测试分析
序号
用户数
每小时业务量
基础数据量
1
6000
180000
无
2
6000
126000
大于1800万
5.2.1平均响应时间对比
F图是不同压力情况下,有基础数据与无基础数据各操作响应时间对比图:
响应时间对比图
」4500用户(无基础数据)■4500用户(有基础数据)16000用户(无基础数据)
」6000用户(有基础数据)
16
14
12
10
8
6
4
2
0
登录开具发票录入并开具
平均响应时间分析:
同样压力的情况下,在无基础数据的情况下,响应时间均小于5秒。
当基础数据量在
1800万的时候,6000用户压力下响应时间大幅度提高,超过客户所提出5秒之内的要求。
5.2.2处理能力对比
下图是相同压力情况下,有基础数据与无基础数据系统的处理能力对比。
TPS寸比图
6000用户(无基础数据)6000用户(有基础数据)
处理能力分析:
在有基础数据的情况下,单从处理能力看,依然可以满足客户所提出的要求,但与之前
的无基础数据的处理能力比较发现,基础数据的存在是对处理能力有较大影响。
5.2.3资源利用率对比图
下图是相同压力情况下,有基础数据与无基础数据各事务资源利用率对比图:
CP利用率对比图
CPU利用率分析:
相同压力下,因有基础数据情况下响应时间变长,系统处理能力下降,CPU利用率也随
之下降,这说明系统瓶颈出现在了其他方面。
5.3系统稳定性测试
在系统测试过程中,我们发现WebLogic的JVM可用内存逐渐减少,下图是在WebLogic
监控台所监控到的情况:
JVM堆中当前可用的內存量仔节卜
为了验证确认此现象,进行了4500用户6个小时的测试,当测试执行到1小时左右,
WebLogicJVM基本已无内存可用,如下图所示:
U
队列怅度:
队列中的等待请求数。
队列已经处理的语求数。
被占用内存无法释放,导致被测系统在长时间运行后响应时间明显上升,处理能力明显
0是|3绘£melmwupdlwQH
Ti■irirgEictld>hRbEpd「兮自Tim*
OGGSDG17
0Q25DO:
關00=4200:
51
Elapsedscenan-otimehh:
mm
00:
5§
m:
i6
下降,如下图所示:
分析:
用户在登录时,系统会自动生成一个session,并占用部分内存,而这个session的过期
时间设置为2小时,按照用户习惯分析,当用户使用直接关闭IE窗口退出系统的方式退出,这个session是不释放的,并继续占用内存。
测试过程中没有做退出操作,导致大量用户session不释放。
根据上图显示,40分钟时性能开始下降,此时在线用户数约为37.5*60*40=90000。
解决方法:
开发人员修改程序,点击重新登录时清除session,并在测试过程中,完成开具发票操
作后就点击重新登录。
重新执行测试后,此现象消失。
5.4有、无合同场景对比测试
在测试过程中,用户提出部分用户需要在开具发票是选择合同,因此设计以下场景进行
测试。
序号
交易
业务配比
执行时间
1
开具发票(无合同)
85%
15分钟
2
开具发票(有合同)
15%
5.4.1响应时间分析
在4500用户压力下,各操作响应时间如下:
业务操作
平均响应时间(秒)
有合同一登录
6.07
有合同开具发票
37.83
有合同—录入并开具
6.38
有合同退出
3.85
有合同选择合同
34.96
无合同一登录
6.27
无合同开具发票
4.45
无合同—录入并开具
6.18
无合同退出
3.84
说明:
此时有合同的开具发票、选择合同操作的响应时间已远远超过5秒,其它大部分操作响
应时间也超过了5秒。
5.4.2处理能力对比图
下图是无合同4500用户与有合同4500用户情况下系统处理能力对比图:
TPS寸比图
分析:
此时系统处理能力仍然满足4小时20万张发票的要求,但因响应时间过长,认为系统性能不满足要求。
5.4.3资源利用率对比图
CP利用率对比图
35
资源利用率分析:
因响应时间过长,出现大量的队列等待,导致CPU利用率下降。
5.5业务场景二调优对比测试
现象:
有合同“开具发票”、“选择合同”操作的响应时间过长。
通过数据库监控可以看到,数据库的读操作过于频繁,dbfilesequentialread等待事件
占总等待时间的92%以上。
分析:
经过对系统的监控,分析得出几点对系统性能可能造成影响的原因:
1、业务逻辑
a)在进入开具发票页面时,系统就加载了全部合同信息,导致“开具发票”操作响应时间过长;
b)查询合同信息业务逻辑有问题,导致“选择合同”操作响应时间过长;
从数据库监控中看到,以下两个SQL的DiskReads最大:
SELECT*FROMHI_BARGAINWHERESKZZH=:
1ANDBG_STATE='正常'
SELECTIV_AMOUNTFROMHI_INVOICEWHEREBG_CODE=:
1AND(IV_STATE='正常’orIV_STATE='冲红')ANDIV_STATE_2='正常’
经开发人员确认,这两个SQL是查询合同信息使用的SQL
2、系统参数
a)WebLogic线程数设置过小;
b)Oracle的sharedpool、buffercache设置过小。
我们对各原因分别进行优化后进行测试,最终进行了以下调整:
1、调整shardpool为104MB
2、调整buffercache为504MB
3、调整查询合同信息业务逻辑
4、修改weblogic线程数为150
调优结果见以下分析。
5.5.1第一次调优
首先修改业务逻辑,在进入开具发票页面时不加载合同信息。
然后修改数据库参数,修
改shardpool为104M、修改buffercache为504M。
F图是4500用户调优前后响应时间对比图:
事务名称
平均响应时间(调优前)
平均响应时间(调优后)
合同_登录
6.07
1.2
合同_开具发票
37.83
1.283
合同_录入并开具
6.38
1.378
合同_退出
3.85
0.232
合同_选择合同
34.96
0.483
开票_登录
6.27
1.215
开票开具发票
4.45
0.568
开票录入并开具
6.18
1.492
开票_退岀
3.84
0.269
050505050
4332211
岀退
*具刃开票录发具
/-录登_
同合
择选
fJ合岸口合
合rf^r前合
■4500用户(调优前)
4500用户(调优后)
4500用尸响应时间对比图
在图中我们可以看出调优前后,在相同压力的情况下,响应时间大幅度下降。
调优效果明显,已满足响应时间小于5秒的业务要求。
此时系统处理能力也有明显的提升。
40
35
30
25
20
15
10
5
0
系统处理能力
□TPS;
1
4500用户(调优前)4500用户(调优后)
5.5.2第二次调优
由于此时WebLogic线程经常出现队列,因此将WebLogic线程最大值由100调整为150。
调整后系统处理能力由36.004上升为37.394。
但由于此时系统处理能力已接近场景设计最
大值,因此效果不明显,需要进行一次6000用户的对比测试。
7
6
5
4
3
2
1
0
登录目发票并开具合同开具^入并口同录
合合同
退出』同登录发票并开具退出合同选牛开票开具J并开票合合同开开票票录开
口开开票
I4500用户
I6000用户
系统处理能力
6000用户时,响应时间明显变长,部分操作已超过5秒,而系统处理能力也有明显的
下降,因此系统仍然存在性能瓶颈。
5.5.3第三次调优
此时主要的优化方向为优化业务逻辑,因此测试人员提出建议,将查询合同信息的两个
SQL合并为一个SQL,这样能够减少大量的查询次数,降低数据库压力。
开发人员将此业务逻辑优化后,进行了一次6000用户的对比测试,结果如下:
6000用户(调优前)
6000用户(调优后)
□TPS
系统处理能力
可以看出,调整业务逻辑后,各操作响应时间大幅度缩短,系统处理能力有了明显提升。
此时系统处理能力达到每小时164876笔。
6测试结论
6.1业务场景一(无合同)
1、系统在测试硬件、无基础数据的情况下,系统处理能力达到每小时173880笔开发票业务,满足客户所提出的4小时处理20万笔开发票业务,响应时间小于5秒的处理能力。
2、系统在测试硬件、有基础数据(1800万条)的情况下,系统处理能力达到每小时122580笔开发票业务,满足客户所提出的4小时处理20万笔开发票,响应时间小于5秒的处理能力。
6.2业务场景二(有合同)
1、系统调优后,在测试硬件、有基础数据(1800万条)的情况下,系统处理能力达到每小
5秒的处理能力。
1、在不影响系统处理能力的情况下,
目前系统最多能够支持
7万用户在线。
根据测试估算,
6.3稳定性
约9万用户同时在线时,会导致系统性能急剧下降,详见5.3。
7调优建议
所提建议仅作为系统进一步优
目前系统处理能力已满足上线后业务高峰期的业务压力,化的参考。
1、增大WebLogicJVM堆大小,可提高最大在线用户数。
当前大小为1000M,最大可设置为1498M。
如需进一步提高在线用户数,可部署WebLogic集群。
2、当系统压力超过测试最大压力时,增大WebLogic线程池大小,可提升系统处理能力。
目前为150,以50为幅度逐步增加。
3、数据库服务器4G的内存下,建议:
PGA建议从默认的24M调整到200M;
SGA建议从默认的138M调整到800M;
buffercache建议从默认的24M调整到500M;
SharePool建议从默认的48M调整到100~200M都可以。
4、建议将数据库连接池最小连接数设置为20。
当数据库连接池可用连接持续为0的情况
下,可增大数据数据连接池大小。
目前为100,可增至150。
5、将所有索引设置为使用INDX表空间,减少资源争抢。
6、User表空间目前使用一个数据文件,建议当User表空间超过10G后,使用多个数据文件,每个数据文件大小不超过10G。
注:
进行以上操作时,应先在测试环境上测试成功后再部署到生产环境上。
8签字确认
负责人:
日期:
北京###软件技术开发有限公司负责人:
日期:
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 最新 性能 测试报告 案例