isTester.com发起人,某互联网测试经理,十年测试经验,公众号“简尚”; 分享实战测试技能、答疑解惑(测试职业探索经验、以及一些书本上学不到的各种职业干货);致力于软件测试从业者综合能力提升。 微信isTester 》》博客文章未标注转载均属「原创」,转载找老徐授权;

「资料合集」性能测试工具LR常见问题汇总

上一篇 / 下一篇  2016-05-17 14:08:01 / 个人分类:测试工具

51Testing软件测试网1j r!b3y ?0R|
本文是收集整理LR常见的问题,如果你有收集整理常见的问题,联系老徐Q957863300补充完善;
本文意义:让所有使用LR的同学,在此处能找到LR日常碰到问题的解决方案。
本文系网络收集,非原创;

1.LR 脚本为空的解决方法:

1)如果安装了IE以外的浏览器,并且IE不是默认浏览器,则无法生成录制脚本

X,t{Ly mdP15203936

2)如果录制脚本时IE不能打开,则需要将浏览器的IE工具高级选项中,将“启用第三方浏览器扩展”的51Testing软件测试网 R3qQ+s'J*JX

勾选去掉51Testing软件测试网9Je/Ab5Z

3)lr自带的webtours系统,如果点击Flights选项,出现空白页面,请检查本机oracle的 PERL5LIB环境

D {^ P;}](Y+u%]15203936

2.LoadRunner录制脚本时为什么不弹出IE浏览器?

当一台主机上安装多个浏览器时,LoadRunner录制脚本经常遇到不能打开浏览器的情况,可以用下面的方法来解决。51Testing软件测试网?/V P-KI'wFj&w%{

启动浏览器,打开Internet选项对话框,切换到高级标签,去掉“启用第三方浏览器扩展(需要重启动)”的勾选,然后再次运行VuGen即可解决问题51Testing软件测试网hvA j:G:`s3_?lj;q

提示:通常安装Firefox等浏览器后,都会勾选上面得选项,导致不能正常录制。因此建议运行LoadRunner得主机上保持一个干净的测试环境。51Testing软件测试网"]YIv/o1sN$G~Nx

3.HTML-based scriptURL-based script的脚本有什么区别?

使用“HTML-based script”的模式录制脚本,VuGen为用户的每个HTML操作生成单独的步骤,这种脚本看上去比较直观;51Testing软件测试网*ba:kk_$QwS&r{e

使用“URL-based script”模式录制脚本时,VuGen可以捕获所有作为用户操作结果而发送到服务器的HTTP请求,然后为用户的每个请求分别生成对应方法。51Testing软件测试网XyQBS8M+P+X

通常,基于浏览器的Web应用会使用“HTML-based script”模式来录制脚本;而没有基于浏览器的Web应用、Web应用中包含了与服务器进行交互的Java Applet、基于浏览器的应用中包含了向服务器进行通信的JavaScript/VBScript代码、基于浏览器的应用中使用了HTTPS安全协议,这时使用“URL-based script”模式进行录制。

h,[^ sBoM&N+X8xC15203936

4.运行时的Pacing设置主要影响什么?

    Pacing主要用来设置重复迭代脚本的间隔时间。共有三种方法:A:上次迭代结束后立刻开始、 B:上次迭代结束后等待固定时间、C:按固定或随机的时间间隔开始执行新的迭代。

-^8juG)j]'pO%Y15203936

     根据实际需要设置迭代即可。通常,没有时间间隔会产生更大的压力。51Testing软件测试网z+a&q)wxo B

 5.运行时设置Log标签中,如果没有勾选“Enable logging”,则手工消息可以发送吗?

Enable logging选项仅影响自动日志记录和通过lr_log_message发送的消息。即使没有勾选,虚拟用户脚本中如果使用lr_message、lr_output_message、lr_error_message,仍然会记录其发出的消息。

$H5TC3ij#C^15203936

6.VuGen会修改录制浏览器中的代理服务器设置吗?

会修改。在开始录制基于浏览器的Web Vuser脚本时,VuGen首先会启动指定的浏览器。然后,VuGen会指示浏览器访问VuGen代理服务器。为此,VuGen会修改录制浏览器上的代理服务器设置。默认情况下,VuGen会立即将代理服务器设置更改为Localhost:7777。录制之后,VuGen会将原始代理服务器设置还原到该录制浏览器中。因此,在VuGen进行录制的过程中,不可以更改代理服务器设置,否则将无法正常进行。

r;pJHD:N)N/}15203936

7.LoadRunner脚本如何输出当前系统时间?

LoadRunner提供了char *ctime(const time_t *time)函数,调用参数为一个Long型的整数指针,用于存放返回时间的数值表示。51Testing软件测试网5D m$njlq

调用语句与返回值如下示例:

f-g(g-wL/?.yLFT*}15203936

typedef long time_t;

p$cc#^+e)V15203936

Action()51Testing软件测试网:l5T,U.M1t;?g

{51Testing软件测试网ntM!dDr*l

time_t t;

*y.[(W%q*XG4o T15203936

lr_message(“Time in seconds since 1/1/70: %ldn”,time(&t));51Testing软件测试网o*vfJo S7W

lr_message(“System time and date: %s”,ctime(&t));

ns~ SP{15203936

}51Testing软件测试网it,w7W[H-?k

输出结果为:

,F.s2Ms@!J9u:j15203936

Time in seconds since 1/1/70: 1185329968

3P ~{(E-x%Z] X$s15203936

System time and date:Wed Jul 25 10:19:28 200751Testing软件测试网4xR4cf-?W;q4qS

8.一些Web虚拟用户脚本录制后立刻回放没有任何问题,但是当设置迭代次数大于1时,如果进行回放则只能成功迭代一次。为什么从第二次迭代开始发生错误?

这种现象多是由于在“Run-time Setting”的“Browse Emulation”的设置中,勾选了“Simulate a new user on each iteration”及其下面的选项“Clear cache on each iteration”这两个选项的含义是每次迭代时模拟一个新的用户及每次迭代时清除缓存。51Testing软件测试网m1]/G8Gy(o$vM2O v

由于脚本迭代时,init和end只能执行一次,如果每次迭代都模拟一个新的用户并清除缓存,则用户登录信息将一并清除,因此迭代时可能会发生错误。

+\V'r2UUcf1\5W.X/pK15203936

9.虚拟客户脚本“Run-time Setting”中的线程和进程运行方式的区别?

如果选择“Run Vuser as a process”,则场景运行时会为每一个虚拟用户创建一个进程;选择“Run Vuser as a thread”则将每个虚拟用户作为一个线程来运行,在任务管理器中只看到一个mmdrv.exe,这种方式的运行效率更高,能造成更大的压力,时默认选项。51Testing软件测试网r-{dgZ~3I&L$k

另外,如果启用了IP欺骗功能,则先在Controller中选中Tools菜单下的“Expert Mode”,然后将Tools菜单下的“Options>General”标签页中的IP地址分配方式也设置为与Vuser运行方式一致,同为线程或进程方式。51Testing软件测试网0Jj7UDX

10.Controller中运行Web相关测试场景时,经常会有很多超时错误提示,如何处理这类问题?

这主要有脚本的默认超时设置引起。当回放Web脚本时,有时候由于服务器响应时间较长,会产生超时的错误。这时需要修改脚本的运行时配置。51Testing软件测试网P{\'Jg ?

进入“Run-time Setting”对话框后,依次进入“Internet Protocol→Preference”。然后点击“Options…”按钮,进入高级设置对话框,可以修改各类超时设置的默认值。

$HJ#fZ g.WD15203936

11.为什么Windows系统中的CPU、内存等资源仍然充足,但是模拟的用户数量却上不去-27796?

     在Windows计算机的标准设置下,操作系统的默认限制只能使用几百个Vuser,这个限制与CPU或内存无关,主要是操作系统本身规定了默认的最大线程数所导致。要想突破Windows这个限制,须修改Windows注册表。以Windows XP Professional为例。

t,s@ `%t*v(E*| I15203936

       (1)打开注册表后,进入注册表项HKEY_LOCAL_MACHINE中的下列关键字:SystemCurrentControlSetControlSession ManagerSubSystems。

0qW3u3f'^ K#L8s&g15203936

        (2)找到Windows关键字,Windows关键字如下所示:51Testing软件测试网e\ Aa-i W

%SystemRoot%system32csrss.exe bjectDirectory=Windows

KE MZfj [R#a15203936

SharedSection=1024,3072,512 Windows=On SubSystemType=Windows ServerDll=basesrv,151Testing软件测试网`([.@!oP)qA n fa#r

ServerDll=winsrv:UserServerDllInitialization,3 ServerDll=winsrv:ConServerDllInitialization,2

I;@ P#@rn]15203936

ProfileControl=Off MaxRequestThreads=16

p|9_#o J7@N15203936

SharedSection=1024,3072,512关键字的格式为xxxx,yyyy,zzz。其中,xxxx定义了系统范围堆的最大值(以KB为单位),yyyy定义每个桌面堆得大小。51Testing软件测试网1C$a'FZz c

       (3)将yyyy的设置从3072更改为8192(即8MB),增加SharedSection参数值。51Testing软件测试网(l4bOPUm

 通过对注册表的更改,系统将允许运行更多的线程,因而可以在计算机上运行更多的Vuser。这意味着能够模拟的最大并发用户数量将不受Windows操作系统的限制,而只受硬件和内部可伸缩性限制的约束。

'?:La2^(t-Z&{cN15203936

 12.性能测试 往往需要准备大批量的数据,大批量数据的生成方法有很多种,常见的有:

(1)编写SQL语句来插入数据51Testing软件测试网V+U1`&mKSZ{8bYO

(2)使用DataFactory等专业的数据生成工具

4rn;li{ m15203936

(3)通过LoadRunner录制回放的方式重复执行生成大批量数据51Testing软件测试网 O e1_~Lo$?g,h#U

        Tips:51Testing软件测试网5UuP Ep l+U|

        使用DataFactory插入nchar数据类型的数据时会出现空值的情况,可以先修改数据库的数据类型设置,插完数据后再改回来51Testing软件测试网+|K8L7dt0[(x

13.录制脚本中包含中文,出现乱码怎么办?

 把录制选项中的Support charset选中UTF-851Testing软件测试网1|Te X g1E,Xae

 录制脚本后,切换到树视图中,打开相应的脚本页面。在右侧的PageView中录制的脚本呈现中文版式,但是当切换到Server Response中,所有的中文全部换成的乱码,如“勌缞仫訆”。51Testing软件测试网@;B b']8}H

原因是服务器端没有把响应的编码设置为gb2312

d@1d7W ?-h15203936

在IIS中找到Web.Config文件,在<system.web>….</system.web>节加入<globalization requestEncoding="gb2312" responseEncoding="gb2312" fileEncoding="gb2312"/>后再次录制脚本,乱码变中文。

UN)}9R*NHE ?)Yt15203936

 14.LoadRunner回放脚本时,在浏览器显示的中文是乱码

解决办法(1):51Testing软件测试网:LVb/b-LAe3b

首先设置Run-Time Settings – Browser – Browser Emulation – User-Agent

&UNr Ft^15203936

然后设置IE51Testing软件测试网7p w?0}:P:W+x2qr5b

查看-编码-钩上“自动选择”和Unicode(UTF-8)。51Testing软件测试网-wdr)W"EYBw

解决办法(2):

olZ+wX3F1wok15203936

使用lr_convert_string_encoding函数来转换编码51Testing软件测试网$Z xot!VD

下面是一个使用的例子:

MLw#YBH15203936

lr_convert_string_encoding(lr_eval_string("{ReplyContents}"),LR_ENC_SYSTEM_LOCALE,LR_ENC_UTF8,"ReplyMessage");51Testing软件测试网a;OW:k:NE-x

       web_submit_data("postreply.aspx_2",

&C&H5{gz#H$vm^p15203936

              "Action=http://127.0.0.1/postreply.aspx?infloat=1&topicid=2&&inajax=1",51Testing软件测试网?$NG"B(B _4f#]

              "Method=POST",51Testing软件测试网DL*w uzs2E

              "EncType=multipart/form-data",

5dNn {,j&J5U$|15203936

              "RecContentType=text/xml",51Testing软件测试网+y#wI h!v

              "Referer=http://127.0.0.1/showtopic-2.aspx",

h#Km"m-f}%~3w15203936

              "Snapshot=t9.inf",51Testing软件测试网Lk;?Aet2i+F

              "Mode=HTML",

u W%b;K.W*b K15203936

              ITEMDATA,

B0P sJ*BE {LB15203936

              "Name=iconid", "Value=0", ENDITEM,51Testing软件测试网0V l#Df"f L^y

              "Name=title", "Value=", ENDITEM,51Testing软件测试网4cW)D P5k

              "Name=wysiwyg", "Value=0", ENDITEM,

-@oIq L9fA15203936

              "Name=checkbox", "Value=0", ENDITEM,

u/bx)\e(V^15203936

              "Name=message", "Value=[localimg=180,112]1[/localimg]rnrn{ReplyMessage}", ENDITEM,51Testing软件测试网tz~~ iX2I7fR

              "Name=e_mediatyperadio", "Value=on", ENDITEM,

,~8u0U DZuX15203936

              "Name=sl_attachdesc", "Value=", ENDITEM,51Testing软件测试网X`$e aof2m&A

              "Name=attachid", "Value=", ENDITEM,

v7lX,k{15203936

              "Name=attachdesc", "Value=", ENDITEM,

?9Rv_ E15203936

              "Name=localid", "Value=", ENDITEM,51Testing软件测试网"M#cJl){w)|

              "Name=attachdesc", "Value=", ENDITEM,

i,YT+R3^-[15203936

              "Name=localid", "Value=1", ENDITEM,51Testing软件测试网+O @+o.]Uw

              "Name=attachdesc", "Value=", ENDITEM,

9e$[-H,IA%o5`15203936

              "Name=localid", "Value=2", ENDITEM,51Testing软件测试网 g"O2QevXn,m+L

              "Name=emailnotify", "Value=on", ENDITEM,51Testing软件测试网;Ev%qhkxx g9y5`

              "Name=postreplynotice", "Value=on", ENDITEM,

c%Z!V~Vs15203936

              "Name=postfile", "Value=", "File=Yes", ENDITEM,51Testing软件测试网O:{-qh4Q-V%{B

              "Name=postfile", "Value=D:图片收集It's about time.JPG", "File=Yes", ENDITEM,

"Vx(zCS6HF/I15203936

              "Name=postfile", "Value=", "File=Yes", ENDITEM,

P&Xh.xO W15203936

              "Name=uploadallowmax", "Value=10", ENDITEM,

5k'Q5tQiX| c]#o]15203936

              "Name=uploadallowtype", "Value=jpg,gif", ENDITEM,

!j!c_'Jb15203936

              "Name=thumbwidth", "Value=300", ENDITEM,51Testing软件测试网_2W!`w-}]D

              "Name=thumbheight", "Value=250", ENDITEM,51Testing软件测试网)g-aWm'd e6z

              "Name=noinsert", "Value=0", ENDITEM,

d(D/b:d x!}-nsxu7x15203936

              LAST);51Testing软件测试网)k_AQ*} J

15.怎样抓取有相同左右边界的动态value

怎样抓取有相同左右边界的动态value?例如:51Testing软件测试网^!cL!Fm

stateID="d7lg0ehmjkkm6uin3s4boei7oq">51Testing软件测试网zQn*lCj.p

stateID="cvopakp46ftsf8mh6l37ti3ubm">51Testing软件测试网a4VE$u/B2RW6`2R

stateID="bv9mja8gtgr39ddibm5t9163re">

RG.UQ:z'G15203936

web_reg_save_param里的ORD应该怎样设置?51Testing软件测试网1oE9l EXl cD

ORD: Indicates the ordinal position or instance of the match. The default instance is 1. If you specify "All," it saves the parameter values in an array.51Testing软件测试网&z%NCC'FY0_u

例子:

d9I&et?Bd;aMf15203936

char outFlightParam[50]; // The name of the parameter for correlation

2U*Y$xX R+eu\15203936

char outFlightParamVal[50]; // The formatted value of outFlightParam51Testing软件测试网7C m'K.{r6]5P,HBA;v

web_reg_save_param("outFlightVal",

$d-W|D$~:T15203936

        "LB=outboundFlight value=", "RB=>",

:\V@6C3p8B9g15203936

        "ORD=ALL",

X5O8u&_?-{15203936

        "SaveLen=18",

+e#wlz]D%B@sv15203936

        LAST);

f4ZE7S O0x UW)W15203936

    web_submit_form("reservations.pl",51Testing软件测试网?5S A7K:FE2`MC

        "Snapshot=t4.inf",51Testing软件测试网 N O D`dBr&`

        ITEMDATA,51Testing软件测试网5U&AU T:TX(\ P6bi

        "Name=depart", "Value=London", ENDITEM,51Testing软件测试网v gK|3|/D

        "Name=departDate", "Value=11/20/2003", ENDITEM,

-N ax8Bz8MB9QB2M15203936

        "Name=arrive", "Value=New York", ENDITEM,51Testing软件测试网 fQ ?;R;J.v k E"l

        "Name=returnDate", "Value=11/21/2003", ENDITEM,51Testing软件测试网NdM;VqEl(C9j

        "Name=numPassengers", "Value=1", ENDITEM,

?9d e#E @|15203936

        "Name=roundtrip", "Value=<OFF>", ENDITEM,

td7Gk7EVl:I%A I3[-@15203936

        "Name=seatPref", "Value=None", ENDITEM,

Pg,]%y$i:]t#edv15203936

        "Name=seatType", "Value=Coach", ENDITEM,

z0ePM$|a15203936

        "Name=findFlights.x", "Value=83", ENDITEM,51Testing软件测试网&ji%F"l2X UZ wQ

        "Name=findFlights.y", "Value=16", ENDITEM,

4z2OC,f(T[6l15203936

        LAST);

D H+Y"S1[p r+dy15203936

    sprintf(outFlightParam, "{outFlightVal_%s}",

5S-o'~3Fh;AuD+G15203936

        lr_eval_string("{outFlightVal_count}"));51Testing软件测试网Mi)^5@] M{

    sprintf(outFlightParamVal, "Value=%s",51Testing软件测试网noI_1Xa g

        lr_eval_string(outFlightParam));

PzZrS'a,}$JP15203936

    lr_message("The value argument is : %s", outFlightParamVal);51Testing软件测试网 { q#Ab4T

    web_submit_form("reservations.pl_2",

f#XGO:C l15203936

       "Snapshot=t5.inf",51Testing软件测试网T"ti!Ew$KG

       ITEMDATA,

1Or;j(^0\ RA15203936

       "Name=outboundFlight",outFlightParamVal, ENDITEM,51Testing软件测试网h f B+[ nXC

        "Name=reserveFlights.x", "Value=92", ENDITEM,

s ?*_$zkG15203936

        "Name=reserveFlights.y", "Value=10", ENDITEM,

A&^ M]l/N|*?15203936

        LAST);51Testing软件测试网0o/V+Y r!d\"^?3Y

16.运行场景时提示“Step download timeout (120 seconds) has expired when downloading resource(s)

vuser_init.c(12): Error -27728: Step download timeout (120 seconds) has expired when downloading non-resource(s)(出现个别,可以忽略)51Testing软件测试网*hJ&o6N3jF{

vuser_init.c(12): Error -27727: Step download timeout (120 seconds) has expired when downloading resource(s). Set the "Step Timeout caused by resources is a warning" Run-Time Setting to Yes/No to have this message as a warning/error, respectively

B o#}gB`15203936

vuser_init.c(12): Error -2779651Testing软件测试网z"A*Jp ~;{+Z4|%Fd

            如果觉得下载一个页面超过2分钟不是错误的话,可以在Run-Time设置中选择Preferences->Options,修改Step download timeout(sec)的时间51Testing软件测试网&o.F8I r,s%R)h,`

TAG: 性能测试工具 软件测试 LR LR常见问题 LR显示浏览器

 

评分:0

我来说两句

显示全部

:loveliness: :handshake :victory: :funk: :time: :kiss: :call: :hug: :lol :'( :Q :L ;P :$ :P :o :@ :D :( :)

Open Toolbar