博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
loadrunner11的移动端性能测试之场景设计
阅读量:5097 次
发布时间:2019-06-13

本文共 4443 字,大约阅读时间需要 14 分钟。

测试步骤之场景设计(Controller)

进入手工场景

准备好脚本后就可以进行场景设计和执行场景了,从VuGen中进入,见下图:

 

 

进入后第一个为目标场景,选择第二个更灵活的手工场景,我的目标人数200,第三个为结果保存地址,最好放到空间比较大的盘中,其他默认即可。

 

确认后进入场景设计页,也可以在【HP LoadRunner】—【Applications】—【Controller】单独进入。选择第一个手工场景,选择左边你需要运行的脚本,点击【Add】添加至场景脚本中,点击确定就ok了,后面再设置虚拟用户即可。

 

成功进入后的场景如下,左上是脚本组,也就是虚拟用户需要运行的脚本,可以设置多个脚本;右上是服务水平协议,暂时不用管;左下是场景计划,用于设置场景运行时间和用户加载退出方式等,右下是交互计划图,看起来很直观,跟你的设置有关。

 

进入目标场景

一般手工场景能灵活地按照需求来设计场景模型,目标场景是测试性能是否能达到预期的目标。场景的设计大同小异,这里以手工场景为例。

 

可以看出,两种场景很相同,只是Schedule配置略有差别。

目标场景的五种目标:用户数(Virtual Users)、点击率(Hits per Second)、每秒事物数(Transaction per Second)、事物响应时间(Transaction Response Time)和每分钟处理的页面数(Pages per Minute)。

点击右下方的【Edit Schedule Goal】,进入设置界面。

 

 

知道怎么创建场景了吧,好的,稍等下,我们先做点准备工作。

 IP欺骗技术

本地设置静态IP

由于是并发用户测试,我了解到LR中,在场景运行时,每台负载发生器计算机上的Vuser都使用其计算机固定的IP地址,这样不能模拟用户使用不同计算机的真实情况。

于是,我们得启用它自带的IP欺骗功能,需要注意IP Spoofer要在连接Load Generator之前启用,并且各负载发生器需要是固定IP,不要使用动态IP(DHCP)。如下图:

 

设置静态IP的流程我就不多说了,网上一大把,Dos命令下,ipconfig  /all可以查看当前的IP,网关和DNS服务器。照着手动修改,不然会断网的。当然前提是你之前也连网了的。

 IP Wizard设置

设置好静态IP后,接着再设置IP Spoofer,选择【开始】—【所以程序】—【HP LoadRunner】—【Tools】—【IP Wizard

】,如下图所示

 

第一个是创建新的设置,以前创建过的选择第二个导入,第三个是释放IP,一般测试完后,需要释放你添加的IP,不然占用多了IP,有时会与别人冲突的。

点击【下一步】,如果计算机有多个网卡,要选择用于这些地址的网卡,再点击【下一步】,在弹出的对话框中设置服务器的IP地址,也就是脚本中请求的地址。

注:服务器与负载机在同一网段的不用设置。

 

 

点击【下一步】后,如下图,再点击图中的【Add按钮】,添加IP。

 

于是到了地址添加界面,下图A,B,C类地址是根据你虚拟用户数来选择的,C类地址只能容纳255个主机,超过这个数就选择其他的两类地址。

注:B类地址范围:172.16.0.0—172.31.255.255 ;A类地址范围:10.0.0.0-10.255.255.255

From ip是起始IP,number to add是增加多少,网关不用管,设置好后,点击【OK】

 

这就是刚生成的地址,错了就选中点击【Remove】,再重新生成。

 

如果生成过程中有下面提示,是指下面地址已经有人使用了,确定后,再重复添加其他地址,这时的From ip就是你最后的那个地址,缺少多少个就添加多少个。

 

最后我生成了200个IP,点击【完成】

 

出现最后确定页,点击【OK】

 

下面就Dos黑窗口,呼呼的往下拉,重启计算机,网络协议才生效,使用ipconfig命令就可以查看是否添加成功了。如下图

 

启用IP欺骗

添加成功后,如下步骤

一,打开conreoller,点击【Scenario】—选【Enable ip spoofer】(允许使用ip欺骗)。

二,然后在conreoller中,点击【tools】—选【expert mode】。

三,最后再点击【tools】—【options】—【General】中关于线程还是进程的设置,这个选项一定要与当前场景的模式相匹配,也就是说使用本地虚拟IP测试时需要选择线程方式,使用负载生成器使用虚拟Ip测试时需要选中进程方式。我的是本地,选的Process。

查看Vusers IP

怎么查看这些IP呢,Controller的运行页,运行场景(Run),在Vusers中,状态列中右键可以查看Vuser日志,弹出的提示框头几行就有显示当前使用的IP.

 

注:不得不说我搞了很久还是没实现这个,原因可能是服务器和客户机不在同一个网段,输入了服务器IP,但是LR的IP向导却没在windows的Temp目录下生成脚本(bat文件),导致不能更新服务器路由表,然后查看Vuser日志也就没显示IP……多次查询资料后又发现win7不支持ip欺骗,即使启用成功,日志显示的就算是不同IP,但抓包会发现请求依旧为同一个固定IP。

 添加Load Generators

说到这里,我再提一下,怎么自行添加负载发生器(Load Generators),如下图所示

一般安装好loadrunner后,都会有localhost这个负载机,点击【Load Generators】后如下

点击【Add】如下,输入Name,选择系统,点击【Ok】即可,注:Name不要随便输入,一般是localhost或者负载机IP地址;Platform指的是负载机的系统。

 

新增负载器后,测试链接,点击【Connect】,如下

成功后就会显示状态为Ready,我这是本地使用了IP欺骗的情况,如下图

 

远程使用其他负载机时,就输入其他负载机的IP即可,记住远程连接之前要在其他负载机【开始】—【所以程序】—【HP LoadRunner】—【Advanced Setting】—【Loadrunner Agaent Process】启动LR agaent代理

场景的集合点设置

登录模块需要测试并发用户,于是前面我在脚本中插入了集合点,需要在运行场景前进行设置,当用户输入验证码后,全部用户到达集合点时,释放用户并进行登录请求,就模拟了用户同时登录的情况。

如下图

依次点击【Scenario】—【Rendezvous…】

 

点击【Policy】进行设置,第一个指所有的用户达到集合点才释放,第二个指所有运行的用户达到集合点就释放,第三个指有X个用户数量达到集合点就释放,最后一个是设置等待时间的,如30秒,30秒内用户达到指定的数量,就开始执行场景,30秒内为达到用户指定的数量,也开始执行场景,不再等待。一般选择第二个就行,点击【ok】

 

运行场景时,可以在上个图片中,启用或关闭集合点,根据情况也可以手动点击【Release】按钮释放集合点。

场景Schdule配置

Schedule基础配置

手动场景Schedule配置,位置如下,左上的场景组可根据需求自行设置

 

Schedule name 场景名称,1场景,2组场景(多个脚本可选择此模式),3真实环境模式(较灵活,很常用)4基本模式,上面的四个按钮暂时不用管,如图默认即可

 

Schedule目标配置

下面接着是目标设置,双击【Initialize】行,进入初始化用户设置,一般选择第三个脚本运行前初始化所有用户,点击【ok】

 

接着双击【Start vusers】行,进入开始用户设置,设置用户数200,每15秒10用户,点击【ok】

 

接着双击【Durations】行,进入运行时间设置,单交易场景一般运行10-15分钟即可,点击【ok】

 

注:场景运行时,设置了运行时间,就会忽略脚本迭代的次数,简单点说就是时间没到,脚本就一直重复运行。

最后双击【Stop Vuser】行,进入用户停止设置,设置和Start Vusers一样即可,点击【ok】

 

以上运行的场景大概设置完了,可以根据自身需求进行更改。

场景图简介

下面说说右边的场景图,横轴纵轴的意义就不说了吧,左斜线代表用户开始运行,中间就是正在运行的用户,右边当然就是退出的用户了,上面的几个按钮自行研究。

注:使用笔那个按钮可以自行拖动设置,+号-号按钮就是放大缩小,很好玩的,场景运行时,该页的用户图也会动态改变的。

 

 

场景运行页

设置好了,开始跑吧,点击【Run】按钮,进入运行场景页。

 

点击后下图所示,左上是用户状态表,状态:关闭(Down),挂起(Pending),初始化(Init),就绪(Ready),正在运行(Run),集合点(Rendezvous),完成并通过(Pass),完成但失败(Failed),错误(Error),逐步退出(GradualExiting),退出(Exiting),停止(Stopped)。

右上可查看事务,用户通过或失败信息。

中间是各种场景监视图表,双击可切换,单击放大。

最下方显示的是图表各参数的数据,可查看最大、最小,、平均值。

 

 Windows资源监视器设置

默认情况下,windows监视器是没有数据的,需要我们自行添加。

右键windows资源图—【Add Measurements】—点击【Add】—输入Name—点击【OK】

Platform选择对应的负载机系统。(注:如果需要监视其他负载机或服务器,Name输入对应IP即可,监视本地时,输入localhost即可。)

 

下图是添加机器后的设置,下面的资源度量指标,可以根据需要自行设置,点击【OK】

 

稍等片刻后,下方就是运行时的windows资源度量指标,用来辅助分析数据和性能瓶颈,服务器资源的监控类似,但Linux类的一般都使用第三方监控工具。

 

运行场景Start Scenario

所有的设置到这里基本完成,点击【Start Scenario】,开始Run吧。

 

耐心等待时,也可以查看运行时的各种图表,Vuser按钮中可查看单个用户的日志(show user log)很有用,前提是在RuntimeSetting中开启扩展日志功能。。

 

添加用户

在负载过程中如果发现系统压力比较小的话,可以自行增加用户数,点击【Vusers】—【Add Vusers】—输入add数—确认脚本—点击【OK】。

见下图说明,注:新增加的用户处于“Down”状态,需要点击Vuser图中的“Run”按钮,才能让用户运行。

 

场景运行的结果会自动保存,退出的时候注意存储位置,以免下次运行时把本次的结果覆盖了。

转载于:https://www.cnblogs.com/qgc1995/p/7264988.html

你可能感兴趣的文章
poj2689(素数区间筛法模板)
查看>>
如何在网中使用百度地图API自定义个性化地图
查看>>
腾讯云无法用域名访问IIS上的网站
查看>>
type convert in python
查看>>
关键字参数
查看>>
Python Cookbook(第2版)中文版
查看>>
TCP协议栈的6类定时器
查看>>
【图论 动态规划拆点】luoguP3953 逛公园
查看>>
【大话存储II】学习笔记(2章), SSD
查看>>
SQLHelp sql数据库的DAL
查看>>
阅读学术论文的心得体会from小木虫
查看>>
Python——Message控件
查看>>
多线程下单例模式:懒加载(延迟加载)和即时加载
查看>>
从 fn_dbLog 解析操作日志(补充update)
查看>>
JavaEE 数据库随机值插入测试
查看>>
this
查看>>
判断对象类型 type()
查看>>
Php函数之end
查看>>
腾讯AB题
查看>>
C# 实现冒泡算法--不一定效率,但很容易理解
查看>>