loadrunner思考时间
篇一:loadrunner基础入门之事务、同步点(集合点)和思考时间、参数化、检查点
事务、同步点(集合点)和思考时间、参数化、检查点
1 Transaction(事务)
事务是计算机程序设计中一个很重要的概念。一个事务应该具有原子性、一致性、隔离性和持久性。在LoadRunner里,我们定义事务主要是为了度量服务器的性能。每个事务度量服务器响应指定的Vuser请求所用的时间,这些请求可以是简单任务(例如等待对单个查询的响应),也可以是复杂任务(例如提交多个查询和生成报告)。
1.1 手动设置Transaction的方法(显式事务)
(1)选择新Transaction开始点,在被度量脚本段之前插入lr_start_transaction。
(2)选择新Transaction结束点,在被度量脚本段之后插入lr_end_transaction。 Lr_start_transaction("login");
web_submit_form("auth",
"Snapshot=t2.inf",
ITEMDATA,
"Name=ssousername",
"Value=robin", ENDITEM,
"Name=password", "Value=123456", ENDITEM,
"Name=remember", "Value=
LAST);
Lr_end_transaction("login”);
1.2 自动事务(隐式事务)
在Run-time Settings中,在Miscellaneous选项卡的Automatic Transactions中定义自动事务。
可以设置LoadRunner直接按事务处理Vuser中的每个Action或step。这里,Action指的是vuser_init、Action和vuser_end三大函数,而step指的是LoadRunner执行的每个函数。LoadRunner将Action名或step名指定为事务名。在默认情况下,将启用按Action使用自动事务的功能,如图下图所示
注意:Transaction的开始点和结束点必须在一个Action中,跨越多个Action是不允许的。
2、Rendezvous Point(同步点,集合点) 只能在Action中添加集合点(不能在vuser_init/vuser_end中添加)。
Lr_rendezvous("the begin port");
3、注释
3.1 用/*注释的话*/
3.2 注释一句话//后面是话
4、Think Time(思考时间)
4.1 定义
用户在执行两个连续操作期间等待的时间称为“思考时间”;lr_think_time的参数单位是秒
4.2 不需要思考时间的时候:
LoadRunner提供了在Run-time Settings中可以设置直接忽略Think Time,而不用修改脚本,如下图所示:
5、参数化(Parameters)
参数化是我们学习LoadRunner中经常用到的功能。除了实现数据驱动之外,参数化脚本还有以下两个优点:
(1)可以使脚本的长度变短。
(2)可以增强脚本的可读性和可维护性。
5.1 参数的创建
5.1.1 脚本视图参数化:新建
选择需要参数化的常量,点击右键选择Replace with a Parameter;弹出参数化设置界面,在“Parameter name”中输入参数的名称,或者选择一个在参数列表中已经存在的参数。在“Parameter type”下拉列表中选择参数类型
1、参数化类型
(1)Data Files
这是我们最常使用的一种参数类型,它的数据存在于文件中。该文件的内容可以手工添加,也可以利用LoadRunner的Data Wizard从数据库中导出。
(2)User-Defined Functions
调用外部DLL函数生成的数据。
(3)Internal Data:虚拟用户内部产生的数据。 Internal Data包括以下几种类型:
A、Date/Time
Date/Time用当前的日期/时间替换参数。要指定一个Date/Time格式,你可以从菜单列表中选择格式,或者指定自己的格式。这个格式应该和脚本中录制的Date/Time格式保持一致。
B、Group Name
Group Name用虚拟用户组名称替换参数。在创建scenario的时候,你可以指定虚拟用户组的名称。注意:当从VU运行脚本的时候,虚拟用户组名称总是None。
C、Load Generator Name
Load Generator Name用脚本负载生成器的名称替换参数。负载生成器是虚拟用户在运行的计算机。
D、Iteration Number
Iteration Number用当前的迭代数目替换参数。
E、Random Number
Random Number用一个随机数替换参数。通过指定最大值和最小值来设置随机数的范围。
篇二:LoadRunner 技巧之思考时间设置
LoadRunner 技巧之思考时间设置
发布时间: 2013-3-11 11:07 作者: 虫师 来源: 51Testing软件测试网采编
字体: 小 中 大 | 上一篇 下一篇 | 打印 | 我要投稿 | 推荐标签: 软件测试 LoadRunner 测试工具 用户访问某个网站或软件,一般不会不停地做个各种操作,例如一次查询,用户需要时间查看查询的结果是否是自己想要的。例如一次订单提交,用户需要时间核对自己填写的信息是否正确等。
也就是说用户在做某些操作时,是会有停留时间的,我把这个时间叫思考时间。但利用代码去执行的时候是没有时间的,当然,脚本运行本身是需要时间的,但比起人的思考时间要小很多。这也是我们为什么要用软件来代替人的某些工作。
但有时候,我们在做性能测试时,为了更真实的模拟用户的操作,需要给代码加入思考时间。来看看在loadrunner是如何设置思考时间的。
打开loadrunner 的Virtual User Generator
菜单栏:Vuser ---Run-Time settings...,切换到Thark Time选项
web_url("www.baidu.com",
"URL=/",
"Resource=0",
"RecContentType=text/html",
"Referer=",
"Snapshot=t1.inf",
"Mode=HTML",
LAST);
web_url("i-1.0.0.png",
"URL=http://s1.bdstatic.com/r/www/img/i-1.0.0.png",
"Resource=1",
"RecContentType=image/png",
"Referer=/",
"Snapshot=t2.inf",
LAST);
web_url("favicon.ico",
"URL=/favicon.ico",
"Resource=1",
"RecContentType=image/x-icon",
"Referer=",
"Snapshot=t3.inf",
LAST);
web_url("su",
"URL=http://suggestion.baidu.com/su?wd=&cb=window.bdsug.sugPreRequest&sid=1466&t=1362
316450913",
"Resource=1",
"RecContentType=baiduapp/json",
"Referer=/",
"Snapshot=t4.inf",
LAST);
lr_start_transaction("注册"); //添加事务
lr_think_time(20); //设置思考时间
web_url("v.gif",
"URL=http://nsclick.baidu.com/v.gif?pid=201&pj=www&rsv_sid=1466&fm=behs&tab=tj_reg&un=&p
ath=http%3A%2F%2Fwww.baidu.com%2F&t=1362316485456",
"Resource=1",
"Referer=/",
LAST);
web_url("favicon.ico_2",
"URL=https://passport.baidu.com/favicon.ico",
"Resource=1",
"RecContentType=application/octet-stream",
"Referer=",
"Snapshot=t5.inf",
LAST);
web_link("注册",
"Text=注册",
"Snapshot=t6.inf",
LAST);
web_custom_request("urs.asmx",
"URL=https://urs.microsoft.com/urs.asmx?MSURS-Client-Key=WI0pAZHPdb%2b3UDOD0AtzxA%
3d%3d&MSURS-Patented-Lock=S1IpDfNCCC4%3d",
"Method=POST",
"Resource=0",
"RecContentType=text/xml",
"Referer=",
"Snapshot=t7.inf",
"Mode=HTML",
"EncType=text/xml; charset=utf-8",
"Body= v=\"3\">
EXTRARES,
"Url=https://passport.baidu.com/img/topbarnav_bg.png",
"Referer=https://passport.baidu.com/v2/?reg®Type=1&tpl=mn&u=http%3A%2F%2Fwww.baidu.com
%2F", ENDITEM,
"Url=https://passport.baidu.com/passApi/js/reg_6e270622.js",
"Referer=https://passport.baidu.com/v2/?reg®Type=1&tpl=mn&u=http%3A%2F%2Fwww.baidu.com
%2F", ENDITEM,
"Url=https://passport.baidu.com/passApi/img/small_blank_9dbbfbb1.gif",
"Referer=https://passport.baidu.com/v2/?reg®Type=1&tpl=mn&u=http%3A%2F%2Fwww.baidu.com
%2F", ENDITEM,
LAST);
web_url("api",
"URL=https://passport.baidu.com/v2/api/?getapi&tpl=mn&apiver=v3&tt=1362316491971&class=re
g&callback=bd__cbs__c93h6w",
"Resource=0",
"RecContentType=text/html",
"Referer=https://passport.baidu.com/v2/?reg®Type=1&tpl=mn&u=http%3A%2F%2Fwww.baidu.
com%2F",
"Snapshot=t8.inf",
"Mode=HTML",
EXTRARES,
"Url=/img/v.gif?type=1®Type=mail",
"Referer=https://passport.baidu.com/v2/?reg®Type=1&tpl=mn&u=http%3A%2F%2Fwww.baidu.com
%2F", ENDITEM,
LAST);
web_url("api_2",
"URL=https://passport.baidu.com/v2/api/?getapi&tpl=mn&apiver=v3&tt=1362316491978&class=re
gPhone&callback=bd__cbs__xs2rv5",
"Resource=0",
"RecContentType=text/html",
"Referer=https://passport.baidu.com/v2/?reg®Type=1&tpl=mn&u=http%3A%2F%2Fwww.baidu.
com%2F",
"Snapshot=t9.inf",
"Mode=HTML",
EXTRARES,
"Url=/cgi-bin/genimage?001362316472015690A3686612594D3D2C14ABF30D0B432CF4462DF3A4B5A8E5E7B7EE094DCAB428311C96E23B35A3CB73A67533699084E25A27CF6C9745497B5C5435611E0593A615CC284B27D70CA5FFB5F771E5D7DC9EE266F6FD61A2D88FEC7B7BA20EFF5DE2CD301E011E634D5063BDDCD35A47C1EB7B5EF365B347DD5800C612B744FAEF845540239F1036
CC800902957BD17F36F6547B71C198C154162F8F71077B935E6B",
"Referer=https://passport.baidu.com/v2/?reg®Type=1&tpl=mn&u=http%3A%2F%2Fwww.baidu.com
%2F", ENDITEM,
"Url=/img/bd-split.gif",
"Referer=https://passport.baidu.com/v2/?reg®Type=1&tpl=mn&u=http%3A%2F%2Fwww.baidu.com
%2F", ENDITEM,
"Url=/img/reg_tip_header_t.gif",
"Referer=https://passport.baidu.com/v2/?reg®Type=1&tpl=mn&u=http%3A%2F%2Fwww.baidu.com
%2F", ENDITEM,
"Url=/img/reg_tip_bg_bottom.gif",
"Referer=https://passport.baidu.com/v2/?reg®Type=1&tpl=mn&u=http%3A%2F%2Fwww.baidu.com
%2F", ENDITEM,
LAST);
篇三:Loadrunner 11的使用
一. 录制脚本
1. 创建一个新的脚本
2. File->New
3. 选择协议
LoadRunner支持多种协议,主要是通过类似插件的dll文件实现的,HTTP协议的解析是通过api_http-filter.dll库文件实现的
? New Single Protocol Script 新建单协议脚本
指我们所有录制的对象只使用唯一的一种协议
? New Multiple Protocol Script 新建多协议脚本
指我们所有录制的对象使用不止一种协议的情况
? New Script Recent Protocol 使用最近使用过的协议新建脚本
指我们所有录制的对象使用最近使用过的协议
选中New Single Protocol Script中的Web[HTTP/HTML]协议,点击
Create
4. 点击Start Record开始录制
Application type应用程序类型
Internet Applications是指我们要录制的对象是一个网络应用(B/S)
Win32 Applications是用来支持Win32的标准客户端的(C/S)
Program to record要录制的程序:我们需要录制的程序名,Loadrunner默认支持的Web客户端是IE URL Address URL地址:我们录制开始所需要访问的URL地址,也就是我们第一个请求所需要访问的
页面。
Working directory工作目录:用来指定录制后脚本所存储的目录
Record into Action录制到操作:我们录制的内容放在哪个Action中。注:Action是loadRunner提供
的一种类似于函数的脚本块,我们通过将不同的脚本块放在不同的Action中
实现代码的高内聚低耦合
Vuser_init存放LoadRunner中用户的初始化操作
Action是非常自由的,可以当做普通的函数
Vuser_end存放LoadRunner中用户的结束操作
Record the application startup指我们一旦启动了应用后就将开始录制我们应用收发的协议 Options设置一些录制选项(如下5)
5. 设置一些录制选项:点击Tools->Recording Options或者在工具栏点击图标
? General 一般的设置
a) Script 脚本选项
默认情况下,LoadRunner的脚本是使用C语言作为标准,在不同的协议下,所支持的
语言也不相同,对于Web(HTTP/HTML)协议,只支持C语言。
Close all AUT processes when recording stops
当VuGen停止录制时,自动关闭所有活动的应用进程
Generate fixed think time after end transaction
在每个结束事务后都添加一个固定的思考时间
Generate recorded events log
描述所有捕获旳事件并生成报告
Generate think time greater than threshold
如果用户超过指定的界限,那么插入用户思考时间
Maximum number of lines in action file
如果一个Action录制的行数超过指定的界限,那么创建一个新的文件
Track processes created as COM local servers
如果录制的一个应用程序的子进程创建为一个COM本地服务器,追踪它的活动
b) Protocols 协议
协议列表,在这里列出所有的协议,我们可以通过协议前的选项来决定使用不同协议来录
制脚本。
c) Recording 录制选项
录制选项,我们选用什么样的录制方式,这里提供了两个大类的录制方式
HTML-based script基于HTML的脚本
这种方式录制出来的脚本是基于HTML基础的。一般来说如果我们是标准使用IE访问的B/S
架构,我们应该使用HTML-BASE下的A script.containing explicit URLs only方式来录制脚本,这种脚本基于URL请求完成,不会带有任何前后依赖的内容。
A script. describing user actions(web_link,web_submit_form)
基于解释用户行为的脚本,注重描述用户做了什么操作类似于QTP,脚本简洁,基于用户操作
模拟,浅显易懂,并且自身就包含了对象检查过程,无需校验
A script. containing explicit URLs only(web_url,web_submit_data)
基于URL请求的脚本录制类型,这种方式不考虑用户的操作,只考虑客户端发送的请求,注重
于实际上系统做了什么
URL-based script 基于URL的脚本
这种方式录制出来的脚本是基于URL请求的。如果我们是一个非IE标准的C/S架构,我们建议
使用URL-BASE来录制脚本,这样我们可以确保不会遗漏任何HTTP请求。
这种是基于URL请求的脚本录制方式,我们会录制得到所有的http请求,生成代码繁琐。
? Data Format Extension 数据格式扩展
Configuration配置
Headers Chain头文件链
Body Chain主体链
Cookies Chain Cookies链
Query String Chain查询字串链
? Network网络
Port Mapping端口映射
? HTTP Properties HTTP属性
Advanced高级
篇四:在LoadRunner的脚步编写中,有三个重要的概念:事务、集合点、思考时间
在LoadRunner的脚步编写中,有三个重要的概念:事
务、集合点、思考时间
事务:
事务又称为Transaction,在LoadRunner中的定义如下:An end-to-end(browser-to-browser) measurement of one or more user actions within action file。中文理解如下:事务(Transaction)是这样一个点,我们为了衡量某个action的性能,需要在action的开始和结束位置插入这样一个范围,这就定义了一个transaction。
事务的作用:LoadRunner运行到该事务的开始点时,LoadRunner就会开始计时,直到运行到该事务的结束点,计时结束。这个事务的运行时间在LoadRunner的运行结果中会有反映。通俗的讲LoadRunner中的事务就是一个计时标识,LoadRunner在运行过程中一旦发现事务的开始标识,就开始计时,一旦发现事务的结束表示,则计时结束,这个过程中得到的时间即为一个事务时间。通常事务时间所反映的是一个操作过程的响应时间。 下面我们说说为什么在LoadRunner中使用事务。为什么使用事务的原因是多种多样的,总结下来如下五点所示:
1、事务是LoadRunner度量系统性能指标的唯一手段;(没有事务则没有办法衡量系统的响应时间,也许有人说LoadRunner可以通过编程来计时得到,不错如果你编程能力够强是能够实现的,但肯定不如LoadRunner中的事务用的简单而且方便)
2、事务能够用于度量高风险业务流程的性能指标;
3、事务能够度量在一组操作中每一步的性能指标;
4、通过事务计时实现了不同压力负载下的性能指标对比;
5、通过事务计时可以帮助定位性能瓶颈;
从性能测试的 角度出发,我们需要知道不同的操作所花费的时间,这样我们就可以衡量不同的操作对被测系统所造成的影响,那么我们如何知道不同的操作所花费的时间,这就用 到了事务,我们在操作之前插入一个事务开始标识,在操作完成后插入一个事务结束表示,这样我们就知道了这个操作所花费的时间。
集合点:
执行负载测试时,需要模拟系统上有较重的用户负载。要实现此操作,可以同步 Vuser 以便恰好在同一时刻执行任务。通过创建集合点,可以配置多个 Vuser 同时执行操作。当某个 Vuser 到达该集合点时,将进行等待,直到参与该集合的全部 Vuser 都到达。指定数量的 Vuser 均到达后,释放所有这些 Vuser。
可通过将集合点插入到 Vuser 脚本来指定会合位置。在 Vuser 执行脚本并遇到集合点时,脚本将暂停执行,Vuser 将等待 Controller 或控制台的允许以继续执行。Vuser 从集合
释放后,将执行脚本中的下一个任务。
注意:只能向 Action 部分(而不是 init 或 end 部分)添加集合。
插入集合点是为了衡量在加重负载的情况下的性能情况。在计划中,可能会要求系统能够承受1000 人同时提交数据,在LoadRunner 中可以通过在提交数据操作前面加入集合点,这样当虚拟用户运行到提交数据的集合点时,LoadRunner 就会检查同时有多少用户运行到集合点,如果不到1000 人,LoadRunner 就会命令已经到集合点的用户在此等待,当在集合点等待的用户达到1000 人时,LoadRunner 命令1000 人同时去提交数据,从而达到计划中的需求
思考时间:
loadrunner 思考时间(think-time)的理解
经常碰到很多网友在问性能测试思考时间的设置,有的设置是默认录制的值,有的是觉得在压力测试时要去掉思考时间这样服务器压力才大,各人的理解不一样其实在测试时是要适当加入思考时间但是时间不能太长一般都是1--5秒内。下面是对思考时间的一些说法。
在录制脚本时 我们一般会选择记录思考时间 record think time,Loadrunner做为性能测试工具,录制时记录的是客户端和服务端的交互,如果要精确模拟 用户的行为,那么客户操作客户端时花费了很多时间要怎么模拟呢?录入填写提交的内容,从列表中下拉搜索选择特定的值等,这时LOADRUNNER 不会记录用户 的客户端操作,而是记录了用户这段时间,成为思考时间(Think-time),因为用户的这些客户端操作不会影响服务端,只是让服务器端在这段时间内没有请求而已。,所以加入思考时间就能模拟出熟练的或者生疏的用户操作,接近实际对于服务端的压力。
Vuser 思考时间模拟实际用户在不同操作之间等待的时间。例如,当用户收到来自服务器的数据时,可能要等待几秒钟查看数据,然后再做出响应。这种延迟就称为“思考时间”。VuGen 使用 lr_think_time 函数将思考时间值录制到 Vuser 脚本中。以下录制的函数指明用户等待了 8 秒钟才执行下一个操作:
lr_think_time(8);
当您运行了 Vuser 脚本并且 Vuser 遇到了上述 lr_think_time 语句时,默认情况下,Vuser 将等待 8 秒钟后再执行下一个操作。可以使用思考时间运行时设置来影响运行脚本时 Vuser 使用录制思考时间的方式。
篇五:loadrunner经典面试题
在LoadRunner中为什么要设置思考时间和pacing
答: 录制时记录的是客户端和服务端的交互,如果要精确模拟 用户的行为,那么客户操作客户端时花费了很多时间要怎么模拟呢?
录入 填写提交的内容,从列表中下拉搜索选择特定的值等,这时LOADRUNNER 不会记录用户 的客户端操作,而是记录了用户这段
时间,成为思考时间(Think-time),因为用户的这些客户端操作不会影响服务端,只是让服务器端在这段时间内没有请求而已。,所
以加入思考时间就能模拟出熟练的或者生疏的用户操作,接近实际对于服务端的压力。
Vuser 思考时间模拟实际用户在不同操作之间等待的时间。例如,当用户收到来自服务器的数据时,可能要等待几秒钟查看数
据,然后再做出响应。这种延迟就称为“思考时间”。VuGen 使用 lr_think_time 函数将思考时间值录制到 Vuser 脚本中。以下录
制的函 数指明用户等待了 8 秒钟才执行下一个操作:
lr_think_time(8);
当您运行了 Vuser 脚本并且 Vuser 遇到了上述 lr_think_time 语句时,默认情况下,Vuser 将等待 8 秒钟后再执行下一个操作。可
以使用思考时间运行时设置来影响运行脚本时 Vuser 使用录制思考时间的方式。 如何理解TPS?
答:TPS主要还是体现服务器对当前录制的事务的处理速度快慢。TPS高并不代表性能好。
TPS 是Transactions Per Second 的 缩 写,也就是事务数/ 秒。它是软件测试结果的测量单位。一个事务是指一个客户机向服
务器发送请求然后服务器做出反应的过程。客户机在发送请求时开始计时,收到服务器响应后结束计时,以此来计算使用的时
间和完成的事务个数,最终利用这些信息来估计得分。客户机使用加权协函数平均方法来计算客户机的得分,试软件就是利用
客户机的这些信息使用加权协函 数平均方法来计算服务器端的整体TPS得分。 如何使用loadrunner批量添加树型结构数据
/*此段代码为:添加”树状”节点数据,代码源于*****项目,此码仅添加数据到第三层。*/
/*前置条件:用户已登录并具有操作权限*/
/*思路:新增一级节点–>获取一级ID–>添加二级节点–>展开一级节点–>获取二级ID–>添加三级数据*/
/*说明:添加一级节点–>逐个读取一级节点ID–>读到一个一级节点就给它添加二级节点–>
二级节点添加完一次就读一次ID–>读一次二级节点直接添加三级节点*/ /*修改”树状”节点数据的代码类似,Submit修改时,要多建一个参数
TreeCode*/
int i,j,k,p; //循环变量
int No1,No2,No3; //分别保存一、二、三级节点的个数
int M1,M2,M3; //分别定义一、二级节点的数量,三级节点不保存数据,故未限制大小
char *MyID1[90],*MyID2[90],m[40]; //MyID1用于储存所有一级节点数据,m为临时数组变量
/* MyID的长度也大于M的长度;m的长度要大于ID的长度+1 */
M1=30;M2=20;M3=10;
/*RootID名称需要按模块修改,Control里需要重新参数化*/
lr_save_string (“FindRootIDinWebResource”,”RootID”);//根节点的ID,修改此处即可使用
lr_output_message (“当前根节点的ID号为:%s”,lr_eval_string
(“{RootID}”));
for (i=1;i<=M1 ;i++ ) //添加M1个一级节点
{
lr_save_int(i,"L");
//#########添加一级节点
web_submit_data("{RootID}{L}");
} lr_output_message ("已添加%d个一级节点",M1);
web_reg_save_param("IDS", //获取一级节点ID
"LB=value=\"",
"RB=\"",
"ORD=All",
LAST);
//#######展开根节点
web_url("{RootID}");
No1=atoi(lr_eval_string ("{IDS_count}")); //获取ID的数量,保存在变更No1中
lr_output_message ("获取一级节点的数量为: %d",No1);
if (No1>M1) { No1=M1;}//让No1<=M1
for (i=1;i<=No1;i++) //将一级节点的ID写入MyID1中
{
sprintf(m,"{IDS_%d}",i); //生成动态字符串{IDS_i},存在变量m中
************核心步骤
MyID1[i-1]=lr_eval_string (m); //读取{IDS_i}参数对应的值,保存到MyID1中****核心步骤
lr_output_message ("一级节点第%d共%d,m=%s即
MyID1[%d]=,%s",i,No1,m,i-1,MyID1[i-1]);
lr_save_string (MyID1[i-1],"SubID");//将MyID1转换为参数{SubID}以便使用
for (j=1;j<=M2;j++ )//添加M2个二级节点
{
lr_save_int(j,"M");
//#######添加下级节点
web_submit_data("{RootID}{SubID}{M}");
} lr_output_message ("已添加%d个二级节点",M2);
web_reg_save_param("IDS2", //获取二级节点ID
"LB=value=\"",
"RB=\"",
"ORD=All",
LAST);
//########展开选中节点
web_url("{RootID}{SubID}");
No2=atoi(lr_eval_string ("{IDS2_count}")); //获取ID的数量,保存在变更No2中
lr_output_message ("获取二级节点的数量为: %d",No2);
if (No2>M2) { No2=M2;}//让No2<=M2
for (k=1;k<=No2;k++) //将二级节点的ID写入MyID2中
{
sprintf(m,”{IDS2_%d}”,k); //生成动态字符串{IDS2_i},存在变量m中************核心步骤
MyID2[k-1]=lr_eval_string (m); //读取{IDS2_i}参数对应的值,保存到MyID2中****核心步骤
lr_output_message (“开始处理@二级节点:第%d共%d,m=%s即
MyID1[%d]=,%s”,k,No2,m,k-1,MyID2[k-1]);
lr_save_string (MyID2[k-1],”SubID2″);//将MyID1转换为参数{SubID}以便使用
lr_save_int(k,”N”);
for (p=1;p<=M3;p++) //添加子节点
{
lr_save_int(p,”P”);
//########添加三级节点
web_submit_data(“{RootID}{SubID}{P}”);
}lr_output_message (“当前状态@一级节点%d,二级节点%d:已添加%d个三级节点”,i,k,M3);
}
}
loadrunner对应用程序性能分析的总结
一个应用程序是由很多个组件组成的,整个应用程序的性能好不好需要从整体入手去分析。
打开analysis页面,将左下角的display only graphs containing data 置为不选,然后选中web page breakdown ,点击“open graph”添加需要分析的功能项。
web page breakdown中显示的是每个页面的下载时间。点选左下角web page breakdown 展开,可以看到每个页中包括的css 样式表,js 脚本,jsp 页面?a href="http://www.zw2.cn/zhuanti/guanyurenzuowen/" target="_blank" class="keylink">人械氖粜浴?/p>
在select page to breakdown 中选择页面。选中后,在选择栏下方看到属于它的组件。哪一行的事物占据的时间较长,那么它的消耗时间点就在这里,分析问题也就要从这里入手。
对相应的组件所标注的颜色分析如下:
1、dns resolution
显示使用最近的dns服务器,将dns解析为ip地址所需要的时间,“dns查找”度量是指示dns解析问题或dns服务器问题的一个很好的指示器。
2、connection
显示与包含指定的URL的web服务器建立初始连接所需要的时间。连接度量是一个很好的网络问题指示器。另外,他还能判断服务器是否对请求作出响应。
3、first buffer
显示从初始HTTP请求(通常为get) 到成功收到来自web服务器的第一次缓冲时为止所经过的时间。第一次缓冲度量可以判断是否存在web服务器延迟或者网络滞后。
注意点:由于缓冲区最大为8k,因此第一次缓冲时间可能也就是完成元素下载所需要的时间。
4、ssl handshaking
显示建立ssl连接(包括客户端请求,服务器请求,客户端公用密钥传输,服务器证书传输及其它部分可选阶段)所用的时间。自此点之后,客户端及服务器之间所有的通信都将被加密。
注意点:ssl握手度量仅适用用https通信。
5、receive
显示从服务器收到最后一个字节,并完成下载之前所经过的时间。
接收度量可以查看网络质量,查看用来计算接收速率的时间/大小比率。
6、ftp authentication
显示验证客户端所用的时间。如果使用ftp,则服务器在开始处理客户端命令之前,必须验证该客户端。、
此功能只是用与使用ftp通信。
7、client
显示因浏览器思考时间或其它与客户端有关的延迟而使客户机上的请求发生延迟时,所经过的平均时间。
8、error
显示从发出HTTP请求到返回错误消息(仅限于HTTP错误)期间所经过的平均时间。
分析以上指标,结合系统资源监控指标,会比较准确快速的定位问题。从而对系统的性能及随后的调优提供针对性的意见。
使用LoadRunner进行性能测试的一般步骤是什么?
☆ 确定需要进行测试的业务或交易,通过手工操作和Vuser Generator的录制功能来记录并生成虚拟用户脚本。
☆ 手工修改虚拟用户脚本,确定脚本能够成功回放。
☆ 在Controller中对场景进行配置后,启动测试。在测试过程中,Controller控制Load Generator对被测系统的加压方式和行为。
☆ Controller同时负责搜集被测系统各个环节的性能数据。各个Loaded Generator会记录最终用户响应时间和脚本执行的日志。
☆ 压力运行结束后,Loaded Generaror将数据传输到Controller中,有Controller对测试结果进行汇总。
☆ 借助数据分析工具Analysis对性能测试数据进行分析,确定瓶颈和调优方法。 ☆ 对系统进行针对性的调优,重复进行压力测试,确定性能是否有所提高。 loadrunner中的设置线程和进程的区别
loadrunner中,在进行运行设置中有一项选择,是按进程运行Vuser或按线程运行Vuser?下面进行分别来讲:
写作技巧