Chinaunix首页 | 论坛 | 博客
  • 博客访问: 1255520
  • 博文数量: 220
  • 博客积分: 0
  • 博客等级: 民兵
  • 技术积分: 1769
  • 用 户 组: 普通用户
  • 注册时间: 2015-03-13 16:19
个人简介

努力, 努力, 再努力

文章分类

全部博文(220)

文章存档

2018年(8)

2017年(46)

2016年(75)

2015年(92)

我的朋友

分类: 系统运维

2015-08-17 19:23:03

引自: http://www.cnblogs.com/fnng/archive/2013/03/04/2943513.html

原文作者:虫师(找bug的程序员) 

    Loadrunner 技巧已经整理4篇了,你个一定疑问,这些知识点,网上随处可见。确实,由于长时间没有使用这个工具,造成我的一些概念开始在大脑中模糊,我只是用这种方式来温习。

----------------------

  在loadrunner的虚拟用户中,术语concurrent(并发)和simultaneous(同时)存在一些区别,concurrent 是指虚拟场景中参于运行的虚拟用户。而simultaneous与集合点(rendzvous point)关系更密切,是指在同一时刻一起执行某个任务的虚拟用户。

  我们来想象一个场景,10名运动员参加长跑比赛,出发点同时起跑,他们是并排奔跑的;跑了N圈之后,因为有体能更强的,有体能稍弱的,他们的队形并排变成了前后。几乎一个跑道就可以供应他们的奔跑(运行),那么其余的9条跑道就是空闲的。

为了充分的利用跑道,可以将跑道的起点设置一个集合点,当所有运动员跑完一圈后在起跑点集合,然后再同时起跑。

运动员可以看作是虚拟用户,跑道可以看作是系统资源。设置集合点可以模式更加真实的并发请求,从而增加对系统的负载。

下面录制一个登录触摸屏版139邮箱的脚本。录制步骤:

1、打开登录页面

2、插入集合点

3、输入用户名密码,点击登录按钮

4、登录页面加载完成,录制结束

 

脚本添加集合点                                                                    

当我们在不熟悉脚本的情况下,可以通过世录制操作面板来添加集合点。

 

如果你非常熟悉每一段脚本代码的作用,可以在脚本中添加:lr_rendezvous 集合点函数。

录制代码如下:

复制代码
Action()
{

    web_url("wapmail.10086.cn", "URL= style="color:#800000;">", "Resource=0", "RecContentType=text/html", "Referer=", "Snapshot=t19.inf", "Mode=HTML",
        EXTRARES, "Url= style="color:#800000;">", ENDITEM, "Url=/favicon.ico", "Referer=", ENDITEM,
        LAST);

    web_custom_request("urs.asmx", "URL=%3d%3d&MSURS-Patented-Lock=NGkcbdtnuEs%3d", "Method=POST", "Resource=0", "RecContentType=text/xml", "Referer=", "Snapshot=t20.inf", "Mode=HTML", "EncType=text/xml; charset=utf-8", "Body=<RepLookup v=\"3\"><G>ED8654D5-B9F0-4DD9-B3E8-F8F560086FDF</G><O>F03F2D77-79E1-4DEC-BBF8-81A5C0790160</O><D>9.0.8110.0</D><C>9.00.8112.16421</C><OS>6.1.7601.1.0</OS><I>9.0.8112.16421</I><L>zh-CN</L><R><Rq><URL>aHR0cDovL3dhcG1haWwuMTAwODYuY24v</URL><O>POST</O><T>TOP</T><HIP>218.204.255.90</HIP></Rq><Rq><URL>aHR0cDovL3dhcG1haWwuMTAwODYuY24vaW5kZXguaHRt</URL><O>POST</O><T>ACTION</T><HIP>218.204.255.90</HIP></Rq></R></RepLookup>",
        LAST);

    web_custom_request("urs.asmx_2", "URL=%2bfaoMg%3d%3d&MSURS-Patented-Lock=EQjsDl4IFSQ%3d", "Method=POST", "Resource=0", "RecContentType=text/xml", "Referer=", "Snapshot=t21.inf", "Mode=HTML", "EncType=text/xml; charset=utf-8", "Body=<RepLookup v=\"3\"><G>ED8654D5-B9F0-4DD9-B3E8-F8F560086FDF</G><O>F03F2D77-79E1-4DEC-BBF8-81A5C0790160</O><D>9.0.8110.0</D><C>9.00.8112.16421</C><OS>6.1.7601.1.0</OS><I>9.0.8112.16421</I><L>zh-CN</L><R><Rq><URL>aHR0cDovL3dhcG1haWwuMTAwODYuY24v</URL><O>PRE</O><T>TOP</T><HIP>218.204.255.90</HIP></Rq></R></RepLookup>",
        LAST);

    
    lr_rendezvous("集合点") //添加集合点 lr_start_transaction("登陆"); //添加事务  web_submit_data("index.htm", "Action= style="color:#800000;">", "Method=POST", "Referer= style="color:#800000;">", "Mode=HTML",
        ITEMDATA, "Name=ur", "Value=fnngj", ENDITEM, "Name=pw", "Value=heng198876", ENDITEM, "Name=apc", "Value=0", ENDITEM, "Name=_swv", "Value=5", ENDITEM, "Name=a", "Value=3,5 ", ENDITEM, "Name=_fv", "Value=3", ENDITEM, "Name=clt", "Value=5", ENDITEM,
        LAST);

    web_submit_data("index.htm_2", "Action= style="color:#800000;">", "Method=POST", "RecContentType=text/html", "Referer= style="color:#800000;">", "Snapshot=t22.inf", "Mode=HTML",
        ITEMDATA, "Name=ur", "Value=XXXXX", ENDITEM, //登陆用户名 "Name=pw", "Value=ooooo", ENDITEM, //登陆密码 "Name=apc", "Value=0", ENDITEM, "Name=_swv", "Value=5", ENDITEM, "Name=a", "Value=3,5 ", ENDITEM, "Name=_fv", "Value=3", ENDITEM, "Name=clt", "Value=5", ENDITEM,
        LAST);

    web_custom_request("handler", "URL= style="color:#800000;">", "Method=POST", "Resource=0", "RecContentType=text/html", "Referer= style="color:#800000;">", "Snapshot=t23.inf", "Mode=HTML", "EncType=application/x-www-form-urlencoded;charset=UTF-8", "Body=&mo=U0j5GuvVaLG3Xz0qMibbQok8g34_OABo&vn=288&vid=&__randomNumber=1362403651558",
        EXTRARES, "Url=/bv1/css/public.css?vn=288", "Referer= style="color:#800000;">", ENDITEM, "Url=/bv1/js/home.js?vn=288", "Referer= style="color:#800000;">", ENDITEM,
        LAST);


    web_custom_request("costanalysis", "URL= style="color:#800000;">", "Method=POST", "Resource=0", "RecContentType=text/html", "Referer= style="color:#800000;">", "Snapshot=t24.inf", "Mode=HTML", "EncType=application/x-www-form-urlencoded;charset=UTF-8", "Body=&mo=U0j5GuvVaLG3Xz0qMibbQok8g34_OABo&vn=288&vid=&cmd=999&d=478&b=1&t=710&body=2&r=5&ajaxInitTime=419&ajaxCostTime=285&ajaxBeginTime=0&downBeginTime=156&initBeginTime=704&logintime=5100&homejstime=2&homeutiljstime=2&ajaxSendTime=1362403651558&redirectTime=-1&__randomNumber=1362403652268",
        EXTRARES, "Url=/bv1/img/global_24.png", "Referer= style="color:#800000;">", ENDITEM, "Url=/favicon.ico", "Referer=", ENDITEM,
        LAST);

    web_custom_request("urs.asmx_3", "URL=%2bdFLSDDAA%3d%3d&MSURS-Patented-Lock=HitWNt%2b1Bns%3d", "Method=POST", "Resource=0", "RecContentType=text/xml", "Referer=", "Snapshot=t25.inf", "Mode=HTML", "EncType=text/xml; charset=utf-8", "Body=<RepLookup v=\"3\"><G>ED8654D5-B9F0-4DD9-B3E8-F8F560086FDF</G><O>F03F2D77-79E1-4DEC-BBF8-81A5C0790160</O><D>9.0.8110.0</D><C>9.00.8112.16421</C><OS>6.1.7601.1.0</OS><I>9.0.8112.16421</I><L>zh-CN</L><R><Rq><URL>aHR0cDovL20ubWFpbC4xMDA4Ni5jbi9idjEvaG9tZS5odG1sP21vPVUwajVHdXZWYUxHM1h6MHFNaWJiUW9rOGczNF9PQUJvJnZuPTI4OCZsb2dpbnR5cGU9MCZjdj0zJnN3dj01JmNsaT01</URL><O>PRE</O><T>TOP</T><HIP>113.108.212.38</HIP></Rq></R></RepLookup>",
        LAST);

    web_custom_request("urs.asmx_4", "URL=%3d%3d&MSURS-Patented-Lock=a7q4TZRzKXk%3d", "Method=POST", "Resource=0", "RecContentType=text/xml", "Referer=", "Snapshot=t26.inf", "Mode=HTML", "EncType=text/xml; charset=utf-8", "Body=<RepLookup v=\"3\"><G>ED8654D5-B9F0-4DD9-B3E8-F8F560086FDF</G><O>F03F2D77-79E1-4DEC-BBF8-81A5C0790160</O><D>9.0.8110.0</D><C>9.00.8112.16421</C><OS>6.1.7601.1.0</OS><I>9.0.8112.16421</I><L>zh-CN</L><R><Rq><URL>aHR0cDovL20ubWFpbC4xMDA4Ni5jbi9idjEvaG9tZS5odG1sP21vPVUwajVHdXZWYUxHM1h6MHFNaWJiUW9rOGczNF9PQUJvJnZuPTI4OCZsb2dpbnR5cGU9MCZjdj0zJnN3dj01JmNsaT01</URL><O>POST</O><T>TOP</T><HIP>113.108.212.38</HIP></Rq></R></RepLookup>",
        LAST);

    lr_end_transaction("登陆",LR_AUTO); //登录事物结束 return 0;
}
复制代码

 

 

控制器中设置集合点策略                                                       

  我们在Virtual User Generator 中回放脚本无法体现集合点的作用。集合点是在多用户并发运行的时候才能起作用。所以,我们需要把脚本导入到Controller 中进行进一步的设置。

1、打开Controller (控制器),导入录制的脚本。

2、菜单栏 Scenario ---> Rendezvous 打开集合点设置界面

 

我们可以看到Vusers 列表框里有10个集合点(1~10),这里的数量和我们设置的虚拟用户数一致。

 我们可以点击选中某个集合点,点击“Disable VUser” 按钮,使其不参与集合点。(某班级早晨集合跑步,A同学肚子痛,经过老师的允许不参与早晨的集合跑步。)

点击“Policy...”来设置集合点的策略:

下面来看看这三种策略的含义

Release when :当所有虚拟用户中的x % 到达集合点进释放,即仅当指定百分比的虚拟用户到达集合点时,才释放虚拟用户。

注意:此选项将会干扰场景的计划。如果选择此选项,场景将不按计划运行。

 

Release when :当所有正在运行的虚拟用户中的x %到达集合点时释放,即仅当场景中指定百分比的、正在运行的虚拟用户到达集合点时,才释放虚拟用户。

  还有不在运行的虚拟用户? 假如,设置为1分钟启动一个用户,当然会存在因为用户还没启动,所以无法参与集合点。

 

Release when : 当个虚拟用户到达集合点时释放,即仅当指定数量的虚拟用户到达集合点时,才释放虚拟用户。

  这个很好理解,当我用百分比不太好衡量集合点的虚拟用户数,当然可以设置具体的用户数。

 

Timeout between Vusers (虚拟用户之间的超时)框中输入一个超时值。

  假如设置了集合10用户并发,结果9个用户已经集合到位,还剩1个虚拟用户,左等右等就是等不来。那总不能一直等下去吧。设定了个时间,假如30秒还不来,那就不管它了。

  超时的时长默认是30秒,我们可以根据具体的被测应用进行调整。


#1楼  Cery   2013-07-18 15:35
你好,我想问一下,集合点,是放在事务中间正确,还是在事务前正确?

是这样的,我测试一个并发:
如果 集合点在事务前面,150并发,响应时间才0.02s,平均
如果 集合点在事务中间(就是并发请求前面),则50并发,响应时间就为30s了,这误差太大了

网上看到的,有在前面的,有在中间的,作为菜鸟,我深受其害。

#3楼 Cery 

我也查了LR的帮助文档和实际测试+网上查阅,果然是
#集合点
#事务开始
#事务结束

才是对的,按你的写法,当并发人数很大的时候,比如500,并发的等待超时时间肯定也算在了事务里面,造成了事务时间长


阅读(1131) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~