LoadRunner性能测试系统学习教程:工具介绍(上)
cac55 2024-09-26 07:27 17 浏览 0 评论
引言
在使用LoadRunner进行性能测试时,需要先了解LoadRunner的工作原理、工作过程和内部结构,这样可以对其有一个整体的了解和概要的认识。
主要包括以下内容:
LoadRunner简介
LoadRunner工作原理
LoadRunner工作过程
LoadRunner内部结构
LoadRunner性能测试步骤
LoadRunner简介
LoadRunner是一种预测系统行为和性能的负载测试工具。以模拟上千万用户并发负载并实时监测系统性能的方式来确认和查找问题。LoadRunner能够对整个企业架构进行测试。通过使用LoadRunner,企业能最大限度地缩短测试时间,优化性能和加速应用系统的发布周期。
目前企业的网络应用环境都必须支持大量用户同时访问,网络体系架构中包含各类应用环境及由不同供应商提供的软件和硬件产品,难以预知的用户负载和愈来愈复杂的应用环境使公司不得不担心会发生用户响应速度过慢、系统崩溃等问题,从而导致公司收益的损失。
MercuryInteractive的LoadRunner能让企业保护自己的收入来源,在无需购置额外硬件的情况下最大限度地利用现有的资源,并确保终端用户在应用系统的各个环节中对其测试应用的质量、可靠性和可扩展性都有良好的评价。
LoadRunner具有的特点
1.按需生产工作量
HPLoadRunner能够驱动成百上千个虚拟用户、执行不同的业务流程、模拟已部署应用程序将要面临的生产条件。这有助于您在投入使用前发现性能和可扩展方面的瓶颈,从而防止它们在投入生产时表现出来。它有助于您极大地降低生产停机时间和不良的性能,使您更加容易达到服务等级和正常运行要求。
2.企业环境支持
VirtualUsers后,测试过程便自动化了。
HP提供广泛的测试环境,支持多种协议和平台。HPLoadRunner现在支持60种以上的协议。其中包括Web、J2EE、.NET、XML、SAP、Siebel、Oracle、PeopleSoft、无线、Citrix和客户端/服务器应用程序。因部署的应用程序类型从客户端/服务器变为Web和Java,故可使用相同的工具来进行性能测试。它提供一个一致的工具和一套员工技能,即使应用程序随时间而改变也如此。它也使得降低总体拥有成本(TCO)成为可能。
3.企业监控支持
HPLoadRunner拥有非侵入性的实时性能监视程序,可提供被测系统所有部分的详细指标。这包括Web服务器、应用程序服务器、数据库、企业资源规划(ERP)和CRM系统、防火墙和负载平衡器。HPLoadRunner可识别硬件局限和软件配置问题,这些问题在其他情况下可能不会被检测到。
4.诊断
HPLoadRunner可跟踪、即使处于负载情况下的单独应用程序组件,并可排除故障。您可从缓慢的最终用户交易着手,深入查明导致变慢的瓶颈方法或SQL语句。这种详细的结果有助于每个负载测试向开发人员提供最终可采取的行动,减少优化J2EE、Siebel和Oracle部署所需的成本和时间。
5.自动分析
HPLoadRunnerAutoCorrelation向导会自动整理所有的监控和诊断数据,并计算导致性能降低的最主要的五个原因。可将性能测试结果转化为可处理的精确数据,从而使开发团队大大减少了解决时间,并允许执行更多的测试周期。这会帮助您将高质量的应用程序投入生产
6.简易使用
HPLoadRunner是从底层为QA用户构建的。它提供可视化脚本语言、数据和AutoCorrelation向导以及ActiveScreen技术,使得编写脚本和运行负载测试简单易行。因此带来更短的起步时间、更快的ROI以及在数周培训之内就能进行性能测试。
7.高度可扩展性
HPLoadRunner对于在有限的硬件条件下的高度可扩展性来说,每个虚拟用户需要较低的CPU和内存资源。这有助于降低实施过程中潜在的硬件成本。
8.统一的脚本引擎
HPLoadRunner与HPBusinessAvailabilityCenter软件具有相同的脚本引擎。
这将帮助您降低培训成本、脚本开发成本以及HP软件TCO(Totalcostofownership,总体成本)。
LoadRunner工作原理
从宏观的角度了解LoadRunner的总体框架、LoadRunner四大组件是如何工作的以及它们之间是如何通信的。
LoadRunner由四大组件组成:VuGen、控制器、负载发生器和分析器。
各组件之间的关系如图
1. VuGen发生器(VisualUserGenerator,VuGen):
它的作用是捕捉用户的业务流,并最终将其录制成一个脚本。在录制脚本前首先选择一种协议(脚本录制前如何选择协议的内容在后面章节中会详细讲述);接着在客户端模拟客户实际使用过程中的业务流程,并录制成一个脚本;然后编辑脚本和设置Run-TimeSettings项;最后VuGen通过对脚本的编译生成一个没有错误的可运行的脚本。
2. 控制器(Controller):控制器部分包含两大作用
第一:设计场景。脚本编辑完成后,必须对脚本如何运行设计一种策略。场景设计主要包括手动场景设计和目标场景设计两种方式;
第二:场景监控。控制器可以实时监控脚本运行的情况。可以通过添加计数器来监控Windows资源、应用服务器和数据库使用情况。
场景设计的目的是设计出一个最接近用户实际使用的场景,场景设计越接近用户使用的实际情况,测试出来的数据就越接近真实值。否则测试出来的数据是不可靠的,到系统上线时可能还是会出现性能问题,场景设计也涉及很多技巧,如IP欺骗、负载均衡等一些手段。
执行实时监控更多的是对资源使用情况的监控,以检测这些系统资源是否可能存在瓶颈。
3. 负载发生器(LoadGenerators):模拟用户对服务器提交请求。
正常情况下,在性能测试过程中会将控制器和负载发生器分开,即控制器使用一台独立的机器,为什么会这样做呢?因为在进行脚本编辑时会产生大量的参数化文件,而这些参数化文件会占用系统资源,再者就是运行时会产生大量的日志文件,所以在测试过程中一般都会将控制器与负载发生器分开;最主要的原因是因为在模拟成百上千的虚拟用户进行性能测试时,每个虚拟用户都是需要消耗系统资源的,如果虚拟的并发用户过多,会导致测试机出现瓶颈。
负载发生器的计算:在测试时,需要计算测试过程中需要使用多少台负载发生器才算是合理的,任何一台计算机所能支持的虚拟用户数都有一个上限值,如果在测试过程中需要测试的并发虚拟用户数超过计算机所能支持的最大虚拟用户数,这时测试的负载机本身也就成为性能的瓶颈。每个虚拟用户运行时需要占用一定的系统内存资源,具体的值可以从官方文档中获得,通过这个值可以计算出一台计算机最多可以支持多少个虚拟用户。例如,假设负载发生器的计算机使用的内存容量为512MB,在测试过程中每个虚拟用户需要的内存资源大概为2.5MB,那么这台计算机最多只能支持200个虚拟用户并发测试,如果需要测试500个虚拟用户并发,那么就需要两台计算机。
需要注意的是当使用多台负载发生器时,一定要保证负载均衡。负载均衡是指在进行性能测试的过程中,保证每台负载发生器均匀地对服务器进行施压。如果负载处于不均衡的情况,那么在测试过程中,有的负载机很忙,而有的负载机又处于很闲状态,这样测试出来的值是不可靠的。
4. 分析器(Analysis):一个数据分析工具,主要用于对测试结果进行分析。Analysis分析器中提供了很多基础的数据,但是仅仅依靠这些基础的数据是不够的,客户看到这样的报告也不会满意。在这里涉及到很多分析技术,常用的分析技术有:合并、叠加、页面细分和钻取技术等,这些技术在后面会进行详细的描述。Analysis的另一个优点就是它本身提供了很多报告的形式,包括XML、Word等,这是LoadRunner做得比较出色的一部分。
以上是LoadRunner四大组件的作用和特点。
LoadRunner工作过程
LoadRunner的四大组件有着各自的作用和特点,但只有将这四大组件联系起来,才能更好地去完成性能测试工作 ,如图:
第一步:很多朋友可能会错误的认为LoadRunner工作的第一步应该是从VuGen开始,但其实LoadRunner在性能测试过程中首先是从控制器开始的,从名字中不难看出,控制器的意思为整个系统的核心,控制着其运行与停止。控制器包括两部分场景设计和场景监控,通过设计控制器中的场景设计性能测试脚本运行的策略,同时在脚本运行过程中监控性能测试的相关指标。
第二步:确定执行策略后,控制器将控制负载机去产生压力,模拟成百上千的虚拟用户去运行脚本,那么负载机如何知道需要执行哪些脚本?以及执行脚本的策略呢?在控制器初始化时,控制器会向负载机发送一个二进制文件,在该文件中记录着如何运行脚本的信息。
第三步:控制器收集测试过程中的相关数据,在控制器执行脚本场景时,控制器会收集测试过程中相关的一些数据,并将这些数据保存在Access数据库中。
第四步:结果分析。当场景执行测试结束后,会生成一些分析结果的数据,这时测试工程师需要对这些数据进行分析,如果结果能满足需求,那么说明系统性能满足需求,反之,就有可能需要多次进行实验,来找到性能瓶颈并向开发工程师提出解决的建议和性能调优的建议。
相关推荐
- 服务器用的CPU和个人电脑用的CPU有什么区别?一篇文章告诉你!
-
服务器cpu和普通cpu的区别你的电脑CPU是‘短跑健将’,服务器CPU却是‘铁人三项选手’——它不追求瞬间爆发力,而要7×24小时扛住千军万马的数据洪流!想知道为什么企业机房敢收天价服务费?答案全藏...
- “吃鸡”新版本第1天,玩家进入游戏点击“立即更新”,后悔了!
-
欢迎诸位小伙伴们来到天哥开讲的《和平精英》“精英小课堂”~每逢两三个月,这款游戏就会迎来一次大版本迭代更新,很多朋友会在第一时间更新版本,前往全新的主题模式里一探究竟。不过也有一些老玩家并不会立刻更新...
- 中关村在线·aigo存储杯《无畏契约》全国高校争霸赛招募启事
-
以青春之名,燃电竞之火1赛事背景与宗旨在金秋送爽的9月,芊芊学子们即将回归校园生活。为了给精彩的校园生活锦上添花,由中关村在线与aigo存储联合主办的《无畏契约》全国高校争霸赛正式启幕,旨在为全国高...
- 【生肖狗】9.7-9.10提醒:人算不如天算,转变即是转机
-
九月上旬的风,带着秋意的清爽,也带着几分不可捉摸的变数。对于生肖狗的朋友们来说,9月7日到9月10日这四天,格外需要留意“计划与变化”的碰撞——你们向来习惯提前规划,做事稳妥周全...
- 转转客服IM系统的WebSocket集群架构设计和部署方案
-
本文由转转技术李帅分享,原题“转转客服IM的WebSocket集群部署方案”,下文有修订和重新排版。1、引言转转作为国内头部的二手闲置交易平台,拥有上亿的用户。用户在使用转转app遇到问题时,一般可以...
- 上线3天Steam好评率86%,《时间旅者:重生曙光》开启生存恐怖新篇章
-
这里究竟发生了什么?末日降临,真正的故事悄然启幕。目前,生存恐怖类游戏《时间旅者:重生曙光(Cronos:TheNewDawn)》已在PC(Steam、EpicGamesStore)、P...
- 什么神仙洗衣机让我一天有28小时?拆开松下「大四洗」藏了啥秘密
-
说起家庭洗衣的烦恼,想必很多人都有过类似的经历:贴身内衣要单独洗,宝宝的口水巾得小心呵护,宠物玩具怕藏污纳垢,床单被套又体积庞大,把这些东西混在一起洗担心越洗越脏,分开洗又得反复操作,洗完烘、烘完再洗...
- 爆料人挖出GTA6注册的奇葩域名 延续经典讽刺风格
-
等待《侠盗猎车手6》的日子跨越了数个春秋,在游戏圈期盼着这部可能成为史上最重磅游戏的过程中,每过一段时间就会有些许消息浮出水面。最新线索来自数据挖掘者Tez2在GTA论坛的发现,他可能偶然发现了关于...
- 跟着故事去旅行——读《驼峰间:旅行、探险与征服》
-
作者:郭冰茹《驼峰间》记录了旅行家伊本·白图泰有生之年流传的一则寓言,说一对父子被关进了监狱,有一天儿子问父亲他们每天吃的都是些什么肉,父亲说有牛、羊和骆驼,并且详细地描述了每种动物的特点。但不管父亲...
- 前端工程师需要熟悉的Linux服务器(SSH 终端操作)指令
-
在Linux服务器管理中,SSH(SecureShell)是远程操作的核心工具。以下是SSH终端操作的常用命令和技巧,涵盖连接、文件操作、系统管理等场景:一、SSH连接服务器1.基本连接...
- 跳票6年后,「丝之歌」首发把Steam服务器干爆了 | 玩点好的
-
文丨果脯樱花隧道昨天晚上22点,「鸽」了6年的《空洞骑士:丝之歌》终于上线,算是了却不少玩家的执念。毕竟,这款游戏实在让人等了太多太多年,而且曾有过多次定档后跳票的「案底」,不知道把多少人都整出了P...
- 对标魔兽失败!腾讯版“魔兽”运营一年多后,宣布国际服凉凉
-
大家好,这里是正惊游戏,我是正惊小弟。有很多游戏都想干掉《魔兽世界》,但是大部分魔兽杀手都知道自己不是魔兽的对手,不过是想蹭一下人气而已。腾讯也有一款曾经想对标魔兽的大作,可是上线才一年半国际服就宣布...
- 408 Request Timeout:服务器等待客户端发送请求的时间过长。
-
408RequestTimeout是HTTP状态码之一,表示客户端在发送请求时,服务器等待的时间过长,最终放弃了处理该请求。此问题通常与网络延迟、客户端配置、服务器设置或者应用程序的性能有关...
- 梦幻西游:9.9维护解读,全新时间服锁定129级
-
梦幻西游:9.9维护解读,全新时间服锁定129级9月9日维护解读。1、教师节活动开启,一共7天。挂机,答题,收笔墨纸砚,收海马,搞起来。或者是提前收点家具,教师节期间体力珍贵,家具会涨价。又或者是教师...
- 只是拆掉一面墙,空间就立马大变样,这种设计思路,值得学习
-
你有没有过这样的经历?刚买的房子户型图看起来方方正正,装修完却发现——玄关鞋柜只能塞在角落,进门就撞墙;餐厅正好在过道中间,吃饭像走流程;明明有四个房间,却有一个空着没用,像块食之无味的鸡肋;客餐厅之...
你 发表评论:
欢迎- 一周热门
- 最近发表
-
- 服务器用的CPU和个人电脑用的CPU有什么区别?一篇文章告诉你!
- “吃鸡”新版本第1天,玩家进入游戏点击“立即更新”,后悔了!
- 中关村在线·aigo存储杯《无畏契约》全国高校争霸赛招募启事
- 【生肖狗】9.7-9.10提醒:人算不如天算,转变即是转机
- 转转客服IM系统的WebSocket集群架构设计和部署方案
- 上线3天Steam好评率86%,《时间旅者:重生曙光》开启生存恐怖新篇章
- 什么神仙洗衣机让我一天有28小时?拆开松下「大四洗」藏了啥秘密
- 爆料人挖出GTA6注册的奇葩域名 延续经典讽刺风格
- 跟着故事去旅行——读《驼峰间:旅行、探险与征服》
- 前端工程师需要熟悉的Linux服务器(SSH 终端操作)指令
- 标签列表
-
- 如何绘制折线图 (52)
- javaabstract (48)
- 新浪微博头像 (53)
- grub4dos (66)
- s扫描器 (51)
- httpfile dll (48)
- ps实例教程 (55)
- taskmgr (51)
- s spline (61)
- vnc远程控制 (47)
- 数据丢失 (47)
- wbem (57)
- flac文件 (72)
- 网页制作基础教程 (53)
- 镜像文件刻录 (61)
- ug5 0软件免费下载 (78)
- debian下载 (53)
- ubuntu10 04 (60)
- web qq登录 (59)
- 笔记本变成无线路由 (52)
- flash player 11 4 (50)
- 右键菜单清理 (78)
- cuteftp 注册码 (57)
- ospf协议 (53)
- ms17 010 下载 (60)