loadrunner 场景设计-目标场景设计
场景设计-目标场景设计
by:授客 QQ:1033553122
A. 概述
Goals Types for Goal-Oriented Scenarios
在以目标为向导的场景中,定义你想实现的测试目标,lr基于这些目标为你自动创建场景。
可以为目标为向导的场景定义以下类型的目标:
1)
Virtual
Users
该目标测试你的应用是否可以同步运行指定数量的Vuser。运行这类goal-oriented场景和运行一个手工场景类似。
2)
Pages
per Minute/Hits per Second/Transactions per Second
这些目标测试服务器能力。对于每个目标,你可以为要运行的场景指定Vuser最小-最大范围。
在有Transactions
per Second目标类型情形下还可以指定一个事务名。
Note:
1、
Pages per Minute and Hits per Second目标仅用于Web
Vusers。
2、
Hits per second
和HTTP
requests per second相关。
当你定义这些目标类型之一时,Controller首先用指定的最小用户数除以定义的目标,得到一个值,然后确定每个用户必须达到的hits/transactions
per second或pages
per minute
然后Controller
根据你定义的负载行为加载Vusers.
如下:
1、
如果你选择了自动运行Vuser(Load
behave->Automatic),lr会在第一批加载50个用户。如果定义的最大Vuser数少于50,lr同时加载所有Vuser。
2、
如果选择的是场景运行一段时间后达到目标,lr就会尝试在这段时间内实现目标。它根据你定义的时间限制及每个用户的点击数,事务数,页面数的计算判断第一批要加载多少用户。
3、
如果选择通过渐变(x
number of pages/hits every x amount of time)来实现目标,lr计算每个用户应该达到的点击数或页面数的目标数量并判断相应的第一批Vuser数量大小
(Not relevant for the Transactions per Second goal
type).
运行每批Vuser后,lr评估每批用户的目标是否已实现。如果没实现,lr重新计算每个用户hits,tranction,pages的目标数量,并为下一批重新调整vuser数量来实现定义的目标。默认的,每两分钟就释放一批vuser。
如果使用了最大数量的用户后,目标未实现,lr通过重新计算target
number of hits, transactions, or pages per Vuser来尝试再次实现定义的目标并同时运行最大数量的Vuser。
Pages per Minute or Hits/Transactions per Second
目标为向导的场景被标记为Failed状态,如果:
1、
控制器已经两次用指定的最大数量的Vuser尝试实现目标,且目标不能被实现
2、
第一批Vuser运行后,没有pages
per minute or hits/transactions per second被登记。
3、
在controller运行一定数量的批次后,pages
per minute or hits/transactions per second的数量不增加。
4、
所用的Vuser运行失败
5、
没可用的负载生成器供指定用户用。
3)
Transaction
Response Time
这个目标测试不超出预期事务响应时间的情况下,有多少用户可以同时运行。可以在脚本中指定事务名,供lr运行的Vuser数量最小最大范围。你指定的事务响应时间应该是一个预定义阈值。例如,如果你不想一个客户登录你的e商务网站的等待超过5分钟,指定一个5分钟可接受事务时间.为服务器可以同时服务的客户数设置最小,最大vuser数。
如果你的场景不能实现你定义的最大事务响应时间,说明你的服务器还有能力接纳定义的虚拟用户的最大数量。如果使用了一部分Vuser,就达到了定义的响应时间或者lr提示如果使用了最多数量的虚拟用时将要超过最大响应时间,那么你应该考虑改造你应用或者更新服务器软件和硬件。.
4)
关注每秒事务数(Transactions
per Second )、事务响应时间(Transaction
Response Time):
1、为了实现一个每秒事务数或事务反应时间,脚本必须包含事务。对于每个这些目标类型,在脚本中定义你想测试的事务。
2、为了使事务反应时间为目标导向的场景有效,必须小心选择事务,确保它在服务器上执行有效
B.
目标场景设计步骤
a)
打开或创建一个场景
1、Start
> Program Files > LoadRunner > Applications
>Controller,在主控制条上点击
New Scenario按钮
.
2、在New
Scenario对话框中,选择Manual
Scenario.
3、从Available选择需要在场景运行的脚本。
b)
添加负载生成器
点击Load
Generator
按钮
(或者Scenario->Load
generators),
在打开的Load
Generators对话框中点击Add并输入你要添加的负载生成器的详细信息
或者如下
点击添加Add
注意:这里的名称可以是ip也可以计算机名、localhost(本机)
点击More
添加后
点击Connect
这里如果Temporary
directory目录为空,那么运行时, LoadRunner存储临时文件在负载生成器上,由负载生成器变量TEMP、TMP变量指定的临时目录.
c)
为每个脚本指定负载生成器
在场景脚本面板中,为每个脚本,点击Load
Generators列并选择用于运行脚本的load
generator
d)
为场景定义目标
在场景目标Scenario
Goal界面上,点击Edit
Scenario Goal按钮,在打开对话框中定义场景应该达到的目标。
e)
为每个脚本指定场景总目标百分比( percentage
of the total scenario target)
在场景脚本面板中 % of
Target列,为每个脚本输入你想每个脚本达到整个目标的百分比。
说明:如果只有一个脚本则为100%.
f)
定义Service
Level Agreements(可选)
你可以定义服务水平协议(service
level agreements.SLAs)
来测量场景目标。在时间间隔内或者整个场景运行期间测量场景目标。
当你稍后用HPLoadrunner
Analysis分析工具分析运行,这些数据在SLAs下进行比较,并且SAL状态将作为定义的测量
loadrunner 场景设计-目标场景设计的更多相关文章
- loadrunner中面向目标场景的设计
在一个面向目标的方案中,可以定义五种类型的目标:虚拟用户数.每秒点击次数(仅 Web Vuser).每秒事务数.每分钟页面数(仅 Web Vuser)或方案的事务响应时间.使用“编辑方案目标”对话框可 ...
- LoadRunner脚本设计、场景设计和结果分析
本次笔记主要记录LoadRunner脚本设计.场景设计和结果分析 1. 脚本设计 录制模式 手工模式:插入步骤.手动编写 1.1 脚本增强: ...
- loadrunner 场景设计-手工场景方案(Schedule)设计
场景设计-手工场景方案(Schedule)设计 by:授客 QQ:1033553122 A. 定义方案schedule 在 Scenario Schedule面板中,选择一个方案schedule, ...
- loadrunner 场景设计-手工场景设计
场景设计-手工场景设计 by:授客 QQ:1033553122 概述 通过选择需要运行的脚本,分配运行脚本的负载生成器,在脚本中分配Vuser来建立手工场景 手工场景就是自行设置虚拟用户的变化,主要是 ...
- loadrunner 场景设计-手工场景方案(Schedule)设计 Part 2
loadrunner 场景设计-手工场景方案(Schedule)设计 Part 2 ---------------------------接Part 1------------------------ ...
- loadrunner 场景设计-手工场景方案(Schedule)设计 Part 1
参考:http://blog.sina.com.cn/s/articlelist_5314188213_1_1.html loadrunner 场景设计-手工场景方案(Schedule)设计 Part ...
- loadrunner基础学习笔记七-面向目标场景
部署应用程序之前,要执行验收测试以确保系统能够承担预期的实际工作量. 可以为想要生成的每秒点击次数,每秒事务数或事务响应时间设置目标 loadrunner将使用面向目标的场景自动生成所需的目标,当应用 ...
- 搭建LoadRunner中的场景(一) 创建场景
一.创建场景 1. 使用场景创建设置对话框 场景分类: 1. 人工场景:相比面向目标场景,人工场景在实际工作中的应用更为广泛. 2. 面向目标场景:预先定义了一个测试目标,LoadRunner将根据这 ...
- LoadRunner创建脚本和场景流程
1)脚本创建流程创建脚本->选择协议-设置录制选项-录制脚本-停止录制-优化脚本(去掉无用内容)-强化脚本(注释.代码结构调整.参数化.检查点.事物.关联)-调试脚本(观察日志) 2)场景设置的 ...
随机推荐
- 纯css实现不同方向的三角形
.triangle { position: relative; &:after { position: absolute; top: 50%; transform: translate(0,- ...
- Python:使用基于事件驱动的SAX解析XML
SAX的特点: 是基于事件的 API 在一个比 DOM 低的级别上操作 为您提供比 DOM 更多的控制 几乎总是比 DOM 更有效率 但不幸的是,需要比 DOM 更多的工作 基于对象和基于事件的接口 ...
- 第三章 服务治理:Spring Cloud Eureka
Spring Cloud Eureka是Spring Cloud Netflix 微服务套件中的一部分,它基于Netflix Eureka做了二次封装,主要负责完成微服务架构中的服务治理功能.Spri ...
- java.lang.IllegalArgumentException: Mapped Statements collection does not contain value for com.bjsxt.mapper.PeopleMapper
报错信息: Type Exception Report Description The server encountered an unexpected condition that prevente ...
- SpringBoot之OAuth2.0学习之客户端快速上手
2.1.@EnableOAuth2Sso 这个注解是为了开启OAuth2.0的sso功能,如果我们配置了WebSecurityConfigurerAdapter,它通过添加身份验证过滤器和身份验证(e ...
- tomcat8 JVM 优化
在Linux环境下设置Tomcat JVM,在/opt/tomcat/bin/catalina.sh文件中找到"# ----- Execute The Requested Command&q ...
- Linux 定时任务 crontab 和 Systemd Timer
一.说说八卦 说到定时任务,我们常用的就是 crond 服务,但是我们不知道还有另外一种定时方式,那就是 systemd,我们常用 systemd 来管理我们的服务,但是我们却不知道,我们还可以通 ...
- MyBatis 分页之拦截器实现
分页是WEB程序中常见的功能,mybatis分页实现与hibernate不同,相比hibernate,mybatis实现分页更为麻烦.mybatis实现分页需要自己编写(非逻辑分页RowBounds) ...
- 自己动手实现java数据结构(一) 向量
1.向量介绍 计算机程序主要运行在内存中,而内存在逻辑上可以被看做是连续的地址.为了充分利用这一特性,在主流的编程语言中都存在一种底层的被称为数组(Array)的数据结构与之对应.在使用数组时需要事先 ...
- Linux 安装 JDK
本篇博客用于记录一下在 Linux 系统下安装 Java 环境. 在大部分的 Linux 系统中都有安装 Open JDK,所以最好是先卸载 Open JDK 后在进行我们的 JDK 安装.Open ...