Loadrunner系统知识(非常好) 下载本文

内容发布更新时间 : 2024/5/22 9:02:11星期一 下面是文章的全部内容请认真阅读。

LoadRunner内部结构

1, 被测系统是由驱动进程mdrv.exe(多线程驱动的进程)和r3vuser.exe来产生压力的,其中r3vuser.exe仿真应用程序的客户端,如IE浏览器。它执行了三个主要的操作:

Kli> cpp (C 语言pre-processor)

1)cci (C语言编译器),建立ci文件,然后使用被测系统的协议相关的驱动来执行。

通过在Windows批处理脚本中启动Mdrv.exe来默默地启动运行。

Mdrv能自动停止加载Vuser,因为他们与Vuser和Windows负载生成器上的CPU使用监视器之间互相通信。

在Windows机器上,对于每一个基于Java的Vuser都有一个独立的JVM。 2, 虚拟用户通过在负载生成器客户端机器上使用agent(3900

magentproc.exe)作为服务或者进程来按照组(在指定的负载生成器上运行相同脚本的虚拟用户的集合)启动虚拟用户。

3, 每一个拥有代理的机器维护一个在.qtp文件中的执行日志。

4, 当日志被启用后,代理同样会在结果文件中为每一个虚拟用户(由虚拟

用户组分开)建立一系列日志文件。

5, 在执行过程中,这些文件可以通过在Controller机器上的view >

Show Output窗口中显示。

6, 在预先设置延时上,Controller上运行的Scheduler指导代理(通过

Windows 54345端口,或者Unix上的动态端口)去初始化场景会话.Controller(wlrun.exe)在请求中发送一份场景的拷贝.

7, 代理是由每一个负载生成器上的Remote Agent Dispatcher进程(以

前叫Remote Command Launcher(RCL))启动的.

8, 每一个根据场景(.lrs)定义文件中设置的代理来决定哪一个虚拟用户组

和脚本需要在主机上运行.

## 这就是说Controller可以从DOS的批处理文件(.batch)中启动. REM Start Controller:

SET M_ROOT=C:\\Program Files\\Mercury Interactive\\LoadRunner\\bin cd %M_ROOT%

wlrun.exe -TestPath D:\\Dev\\Dev1.lrs -port 8080 -Run -DontClose ? 包含的-Run 参数与手动的点”开始场景”自动运行是一样的. 这不是一个很好的方法,因为你可能需要决定从以前的运行中收集文件或者想改变输出文件夹.

? 这是假设系统环境变量PATH已经被更新了,包括LoadRunner的安装. 9, Controller通过使用 Windows 操作系统文件夹里的参数值来启动.因为

LoadRunner被设计成在一个机器上一次只能运行一个Controller实例,所以需要使用Windows文件夹.

## 为了在几个应用之间快速的切换, 在Controller工作之后保存

LoadRunner的ini文件, 然后使用记事本来制作一个批处理文件. 在执行

1

wlrun之前拷贝应用程序的指定版本的ini文件. 下面是一个应用程序文件拷贝的例子:

copy %WinDir%/wlrun7-XXX.ini %WinDir%/wlrun7.ini copy %WinDir%/wlrun7-XXX.dft %WinDir%/wlrun7.dft 需要修改一些默认值:

? 在wlrun7.ini文件的output区域,

MaxNumberOfOutputMessages=from 10000 to 100000, 这就限制了存储在数据库中的输出信息的数目.

? MaxOutputUIRowsToShow限制了在Controller的输出窗口中显示的信息/错误行总数.

? 在LoadRunner程序文件的 dat\\protocols 文件夹下的

QTWeb.lrp文件的[Vugen]部分, 添加一个MaxThreadPerProcess=5来限制由每个负载生成器mdrv.exe进程管理的线程数.

? 存储在wlrun5.ini 和wlrun7.dft文件中的DefaultScenarioDir, DefaultscrīptDir, DefaultResultDir,[Recent File List]几个数据的值会在每次Controller改变的时候更新。

10, 在Vu scrīpts中定义的每个虚拟用户进行的操作是用LoadRunner

的VuGen.exe生成的. 当这个程序启动后, 它在windows文件夹下存储了comparamui.INI文件来保存[LastTablesUsed]下面文件的历史,并且保存由Insert > New Parameter > Dates 菜单指定的[ParamDialogDates].

VuGen在Windows文件夹下存储和检索vugen.ini文件.当使用JAVA的时候,需要添加一些其他的调试选项: [DynaDlg] JavaLevel=3

当在VuGen 8.1中使用8.0的脚本, 往Vugen.ini中加入信息: [Editor]

OLDEDITOR = 1

VuGen在LR文件夹template/qtwebdefault.cfg里和脚本文件里打开. Vu scrīpts可以使用脚本外部的参数文件来获得的变量值进行编码. 更多关于VuGen的信息请看脚本编写的章节.

11. 运行过程中,执行结果存储到一个结果文件夹中.

我喜欢在场景执行中把结果设置成自动产生结果.这样,LoadRunner会在每次启动一个场景之后自动产生一个子增的结果名. 例如,结果名称Res1会自动增长到Res12或有时候是R es11-1.

错误被写到output.mdb微软的Access数据库中。

12. 在每一个结果文件夹中, 程序自动创建Log文件夹来包含每个组的日志文件. 运行之后,在Controller中查看日志文件,点 , .然后在组中点右键,选择 “Show Vuser Log”

13. 场景运行的时候, 监视器在本地维护每个主机的计数器.

14. 运行完成之后, \进程处理.eve和.lrr结果文件, 并且在结果文件夹下创建一个临时的.mdb数据库.

在处理大数据量的结果时, 为了防止错误发生,使用MSDE. ……

2

15.分析模块(8,320K analysisu.exe)使用mdb数据库中的数据来产生分析图表和报告.

16. 每一次场景运行后的结果文件results_name.lrr,也叫分析文档文件,由分析程序来读取并且显示百分位图表.

Loadrunner系列学习--Loadrunner架构(1)

一:Loadrunner结构概述

Loadrunner通过使用虚拟用户代替真实用户操作客户端软件来工作的,例如使用IE对IIS或者Apache Web服务器发送HTTP请求.

多个虚拟用户客户端的请求是有负载生成器(Load Generator)产生的,目的是对不同类型的被测服务器产生负载.

这些负载生成器代理(load generator agent )是由Mercury's的控制器(Controller)来控制启动或停止的.

控制器根据由编译的脚本引起的场景(Scenarios)和相关的运行时设置(Run-time Settings)来控制负载测试的运行.

这些脚本是由虚拟用户脚本生成器(Virtual user scrīpt Generator)也叫VUGen生成的.它是通过截获网络应用程序的客户端和服务器之间的网络通信包而产生的C语言脚本,这些脚本可以被虚拟用户执行.

对于Java客户端,VuGen通过客户端的JVM的钩子技术来捕获请求. 在运行时,每个机器的状态由控制器监控.

运行结束后,控制器把监视日志和右负载生成器产生的日志结合起来给分析器(Analysis)使用.分析器能够把这些日志生成结果报表和Microsoft Word格式的图表,水晶报表或HTML格式页.

每一个由分析器生成的HTML报表页包括一个到结果的超链接,这些结果文件可以用Microsoft Excel打开来进行其他的分析.

运行时产生的错误都被存储在一个数据库中,该数据库可以用Microsoft Access打开. 虚拟用户:

3