(转)LoadRunner 技巧篇

上一篇 / 下一篇  2008-12-20 12:15:05 / 个人分类:LoadRunner

 性能测试是一件非常严谨的事情,很多人在做性能测试的时候只是关注工具如何去用而很少关心如何去做好性能测试的准备,建模等工作。以下是在性能测试中lr模拟的一些常见问题。

     .网络带宽问题。

     对Web进行压力测试时,通常百兆网络是不够的,当网络带宽不够的时候server端没有足够压力。用LoadRunner所在的Windows的性能管理器看一下网络利用率就知道了。

     .Vuser脚本的检查。

     Loadrunner提供了方便的脚本录制功能,但由于录制时可能出现的操作错误,vuser访问一些不存在的资源。去除某些与压力测试无关的东西。否则可能会出现Loadrunner测试结果有误或压力上不去的情况

    .Runtime setting。

    在创建Loadrunner scenario时,每台机器的vuser的runtime setting都应该分别设置并检查,不能只对第一个vuser的runtime setting进行设置。通常你会关掉think time,以便能用较少的机器达到较大的压力。另外,如果返回页面里包含了一些访问其它资源的链接比如图片服务器,这时应关掉 download non-html resources。

    .没有检查返回页面。

    当server端出错时应用程序有可能返回错误信息,但对HTTP来讲仍是成功的响应,返回码为200 O.K. 这样在Loadrunner就被记为成功的transaction。于是,server端出错越多,Loadrunner测出的性能越好。解决办法:开启并检查应用的错误日志;或者启用Loadrunner的返回内容检查功能。

    .当心Loadrunner所在机器的磁盘空间。

     缺省情况下Loadrunner会把运行结果的详细信息放在C盘的Documment and Settings的用户目录下,当大压力长时间运行或有大量出错时,Loadrunner会生成大量的数据到该目录下。当磁盘空间满了后,机器的响应将变得很慢。

命令行打开LoadRunner

   在多个场景需要运行的时候,可以通过批处理循环运行场景,保存结果到指定文件夹:

   bat内容:

set LR_HOME=C:\Program Files\Mercury\LoadRunner
for /L %%iScenario   in (1,1,10) do "%LR_HOME%\bin\Wlrun.exe" -Run -TestPath "%LR_HOME%\scenario\memory_leak_crash.lrs" -ResultName C:\LR_Result\result%%iScenario

. 既可以验证请求的正确性又Vさ玫秸返氖奔?/FONT>

  由于lr的http 200的经典错误,所以需要加入验证点,如果加入了验证点,就使事务响应时间大于实际的响应时间,如何解决呢,利用lr_waste_time解决,代码如下。

   double time_elapsed, duration, waste;

   merc_timer_handle_t timer;

   lr_start_transaction("sampleTrans");

   web_url("index.htm",
           "URL=http://localhost/index.htm",
           "TargetFrame=",
           "Resource=0",
           "RecContentType=text/html",
           "Referer=",
           "Snapshot=t1.inf",
           "Mode=HTML",
           LAST);

   timer = lr_start_timer();

   // Do some checks the duration of which is not to be included in the transaction.

   web_image_check("ImgCheck1",
           "src=index_files/image002.jpg",
           LAST);

   web_image_check("ImgCheck2",
           "src=index_files/planets.gif",
           LAST);

   // How long did the tests take in seconds.

   time_elapsed = lr_end_timer(timer);

   // Convert to millisecond.s

   waste = time_elapsed * 1000;

   // Remove the time the checks took from the transaction.

   lr_wasted_time(waste);

   lr_end_transaction("sampleTrans", LR_AUTO);


TAG:

引用 删除 七格格   /   2009-05-27 11:07:46
好详细...顶了..
 

评分:0

我来说两句

Open Toolbar