LoadRunner性能测试应用文档格式.docx
《LoadRunner性能测试应用文档格式.docx》由会员分享,可在线阅读,更多相关《LoadRunner性能测试应用文档格式.docx(15页珍藏版)》请在冰豆网上搜索。
通过“Vuser”菜单来启动录制脚本的命令,如图2-6所示。
图2-6选择录制按钮
也可以在工具栏中直接单击“StartRecording”按钮,但录制之前还要进行相应的设置,如图2-7所示。
图2-7录制配置界面
<
1)环境设置
首先,勾选“Recordtheapplicationstartup”,单击“OK”后,就会自动启动要测试的程序,还可以选择要把录制的脚本放到哪一个部分,默认情况下是“Action1”。
然后,单击左下角的“Options”按钮,进入录制环境设置界面,如图2-8所示。
●“Recording”标签页:
默认情况下选择“HTML-basedScript”,说明脚本中采用HTML页面的形式,这种方式的Script脚本容易维护和理解,推荐用这种方式录制。
“URL-basedScript”说明脚本中的表示采用基于URL的方式,WAS和ACT中的录制方式就是这种,这种方式看上去比较乱。
其他标签页功能说明如下,如有需要可作相应的设置。
●“Browser”标签页:
浏览器的选择。
●“RecordingProxy”标签页:
浏览器上的代理设置。
图2-8环境设置界面
●“Advanced”标签页:
可以设置录制时的思考时间<
ThinkTime)、支持的字符集标准等。
●“Correlation”标签页:
手工设置关联,通过关联可在测试执行过程中保存动态值。
使用这些设置可以配置VuGen在录制过程中执行的自动关联的程度。
2)脚本内容
在录制过程中,可以单击“Pause”<
暂停录制)按钮,在脚本中插入事务、注释和集合,防止在录制完成后再插入这些事务找不到具体位置。
当业务流程完成后,单击“Stop”<
停止录制)按钮,会自动生成脚本,退出录制过程,如图2-6所示。
单击“Save”<
保存)按钮,起个与实际业务有关系的名字,保存到相应的位置。
使用VuGen录制之后生成的每个Vuser脚本都至少包含vuser_init、一个或多个Actions及vuser_end等三部分。
在通常情况下,将登录到服务器的活动记录在vuser_init部分中,将客户端活动录制到Actions部分中,并将注销过程录制到vuser_end部分中。
因为运行多次迭代的Vuser脚本时,只有脚本的Actions部分重复,而vuser_init和vuser_end部分将不重复。
脚本图例如图2-9所示。
图2-9脚本图例
在录制脚本期间,发出的消息可以通过日志来查看,选择“View”>
“OutputWindow”,然后选择“RecordingLog”选项卡。
可以在“RuntimeSetting”的“Log”选项卡中设置该日志的详细级别,如图2-10所示。
图2-10录制日志
录制时,VuGen会创建一系列配置、数据和源代码文件。
这些文件包含Vuser运行时和设置信息。
VuGen会将这些文件连同脚本一起进行保存。
至此,一个完整的Vuser脚本录制完成。
多协议脚本的录制与单协议脚本的录制过程基本相同,只是比单协议脚本的录制多一个选项界面,如图2-11所示。
在此界面中单击协议,可以进行添加和删除协议的操作。
在协议前的复选框中打对号,即为选中,否则删除。
图2-11添加协议
2.1.2录制WebServices脚本
在进行性能测试时,大部分对Web性能测试,选择“Web<
HTTP/HTML)”协议即可,但录制完脚本后,回放脚本过程中有时会发生中断或停止的情况,查看错误时,如果无法找到SOAP文件字样时,就需要考虑更换脚本录制协议了。
通常首先考虑更换WebServices协议,再次录制脚本,问题就相应解决了。
在录制WebServices脚本前,首先对WebServices做一个简要的介绍,这样有助于读者或者测试人员能够更好地利用WebServices协议录制脚本。
1.什么是WebServices
WebServices是一种构建应用程序的普通模型,并能在所有支持Internet通信的操作系统上实施运行。
WebServices令基于组件的开发和Web的结合达到最佳,基于组件的对象模型,如:
分布式组件对象模型<
DistributedComponentObjectModel,DCOM)、远程方法调用<
RemoteMethodInvocation,RMI)、互联网内部对象请求代理协议<
InternetInter-OrbProtocol,IIOP)都已经发布很长时间,但是它们都依赖于特殊对象模型协议。
而WebServices利用SOAP和XML对这些模型在通信方面作了进一步的扩展,以消除特殊对象模型的障碍。
进一步地,WebServices还基于HTTP和SOAP协议,使得Web用户通过Web调用的方法使用SOAP和HTTP来调用远程对象,确保业务数据得以在Web上传输。
2.WebServices结构
客户根据WSDL描述文档,会生成一个SOAP请求消息。
WebServices都是放在Web服务器<
如IIS)后面的,客户生成的SOAP请求会被嵌入在一个HTTPPOST请求中,发送到Web服务器,Web服务器再把这些请求转发给WebServices请求处理器。
请求处理器的作用在于,解读收到的SOAP请求,调用WebServices,然后再生成相应的SOAP应答。
Web服务器得到SOAP应答后,会再通过HTTP应答的方式把信息送回到客户端。
3.WebServices体系
WebServices体系主要包括以下几个方面:
1)WebServices包括3种组件。
服务提供者:
提供服务,进行注册以使服务可用;
服务代理者:
服务交换所,服务提供者和服务请求者之间的媒体;
服务请求者:
向服务代理请求服务,调用这些服务创建应用程序。
2)WebServices提供3种操作。
发布/不发布<
Publish/Unpublish):
服务提供者向服务代理者发布<
注册)服务或不发布<
移去)这些服务的注册;
发现<
Find):
由服务请求者向服务代理者执行发现操作,服务请求者描述要找的服务,服务代理者分发匹配的结果;
绑定<
Bind):
在服务请求者和服务提供者之间绑定,这两部分协商以使请求者可以访问和调用提供者的服务。
3)UDDI规范
统一描述、发现和集成<
UniversalDescriptionDiscoveryandIntegration,UDDI)是一个WebServices的信息注册规范,基于UDDI的WebServices注册可以被发现。
UDDI的核心部分是UDDI业务登记逻辑,即在Web上有一种分布的注册服务,这种服务以一种通用的XML格式进行描述。
通过XML中的结构化描述,可以很方便地在互联网上发现需要的数据,进而方便进行分析和操作。
从概念上看,一个UDDI业务登记逻辑所提供的信息包括三个部分:
“白页”包括地址、协议和已有标识;
“黄页”包括基于分类标准的工业类型;
“绿页”是关于企业所包含的服务技术信息,包括网络服务说明参考和根据发现机制对各种文件和网址提供的标识支持。
4)网络服务描述语言<
WSDL)
网络服务描述语言<
WebServicesDescriptionLanguage,WSDL)遵循XML语法,为服务提供者提供了描述构建在不同协议或编码方式之上的WebServices请求基本格式的方法。
WSDL用来描述一个WebServices能做什么,它的位置在哪里,如何调用它等。
在假定以SOAP/HTTP/MIME作为远程对象调用机制的情况下,WSDL会发挥最大作用。
UDDI注册描述了WebServices绝大多数方面,包括服务的绑定细节。
WSDL可以看作是UDDI服务描述的子集。
WSDL将服务定义为一个网络端点的集合,或者说端口的集合。
在WSDL里面,端点及消息的抽象定义与它们具体的网络实现和数据格式绑定是分离的。
这样就可以重用这些抽象定义:
消息<
需要交换的数据的抽象描述)和端口类型<
操作的抽象集合)。
针对一个特定端口类型的具体协议和数据格式规范构成一个可重用的绑定。
一个端口定义成网络地址和可重用的绑定的连接,端口的集合定义为服务。
因此,一个WSDL文档在定义WebServices时使用如下的元素:
类型——使用某种类型系统定义数据类型的容器;
消息——通信数据抽象的有类型的定义;
操作——服务支持动作的抽象描述;
端口类型——操作的抽象集合,该操作由一个或多个端点支持;
绑定——针对一个特定端口类型的具体协议规范和数据格式规范;
端口——单一的端点,定义成一个绑定和一个网络地址的链接;
服务——相关端点的集合。
不难看出,WSDL给客户提供了一个模板,方便客户描述和绑定服务。
上面简单介绍了WebServices基本的知识,下面采用WebServices单协议进行简要的脚本录制,读者可结合录制脚本的过程进一步了解它,具体步骤如下:
选择“开始”>
“程序”>
“LoadRunner”>
“VirtualUserGenerator”<
Vuser生成器),启动VuGen。
在VuGen的“File”下拉菜单中选择“New”,新建一个脚本;
从“Category”<
类别)列表中选择“WebServices”协议,单击“OK”按钮开始录制Vuser脚本。
首先配置WebServices录制向导,配置程序录制的方式。
“RecordClientApplication”方式是通过客户端进行录制的,“ScanWSDLfile”方式需要录入WSDL文件才可录制,在这里选择“RecordClientApplication”进行录制,如图2-12所示。
“SpecifyWSDLfilesforrecording”向导用于配置WDSL文件,因为选择“RecordClientApplication”的录制方式,所以在此选择“DonotuseWSDLfileduringrecording”,表示不利用WSDL文件进行录制,如图2-13所示。
图2-12WebServices录制界面1图2-13WebServices录制界面2
“Specifyapplicationtorecord”向导用于配置程序的访问地址、浏览器和录制脚本中的一些初始化设置。
在URL中添加测试程序的访问地址;
如果程序需要其他的浏览器,选择“Recordanyapplication”进行其他浏览器的设置,这里不需要特殊的浏览器,所以不选择此项;
“Recordintoaction”选项用于指定把录制的脚本放到哪一个部分,一般初始化放在vuser_init中,循环部分在Action中,结束退出部分放在vuser_end中,如图2-14所示。
如有需要请单击后面的“AdvancedDetails”按钮,可以详细地配置“OptionsRecording”用来录制脚本,这里不介绍OptionsRecording,在以后的章节中有详细的介绍。
单击“完成”按钮即可完成WebServices的向导配置。
然后VuGen将根据程序的访问地址自动启动应用程序,并显示“Recording…”<
录制)工具栏,开始脚本的录制,如图2-15所示。
图2-14WebServices录制界面3
图2-15“Recording…”工具栏
在整个操作过程完成后,单击“停止”按钮,脚本录制结束,LoadRunner自动把录制的内容保存在脚本中。
在录制完毕的脚本中会出现一些函数,在后面章节中会详细介绍这些函数的使用方法。
一个生成的WebServices的脚本节选如图2-16所示。
图2-16WebServices脚本图例
这样就完成了WebServices单协议脚本的录制过程。
2.1.3回放脚本及调试
录制完脚本后,需要单机运行一下脚本,因为在录制脚本的过程中可能会出现错误。
例如:
有些连接、图片或界面无法找到,需要调试;
有些地方需要参数化,只有唯一值才能执行通过;
还有可能回放脚本时出现-404、-500等错误页面,发生超时等现象。
这时就需要把这些问题解决掉。
单击工具栏中的“Compile”按钮,查看脚本中是否有语法或者乱码错误,如果出现错误需要手工及时调试,如果没有错误,在执行日志中显示“Noerrordetected”消息提示。
然后,单击工具栏中的“Run”按钮,开始执行脚本,在执行脚本期间,同样可以通过日志来查看发出的一些消息。
选择“View”>
“OutputWindow”,再选择“ExecutionLog”选项卡。
如果有错误,VuGen将会提示错误。
双击错误提示,VuGen能够定位到出现错误的那一行,如图2-17所示。
图2-17提示运行脚本错误
单机运行测试脚本后,如果编译通过,就会开始运行,运行结果如图2-18所示。
在每次单击回放脚本后,都会出现如图2-18所示的运行结果页。
在结果页中可以清楚地看到脚本运行的情况,显示整个运行过程中出现成功、失败和警告情况各自的运行时间,并且记录下整个运行开始、结束的日期和时间。
图2-18单机运行脚本结果
如果整个运行过程成功,在页面的左侧是整个脚本的树型结构,显示出的每个脚本的控件名称前都有绿色对号的标志,例如图片、链接、提交表单等,如图2-19所示。
图2-19运行成功时的结果页
单击某个控件,在其右边便显示出其控件的页面或相应的运行步骤,如图2-20所示。
图2-20显示运行成功步骤
在此结果页中还可以检测脚本中控件或者其他错误,如果脚本回放出现错误的话,会在相应控件前出现红色叉号的错误提示,如图2-21所示。
图2-21运行失败的结果页
单击其控件后,在右边出现脚本未通过的具体原因,以便查找出错位置进行改正,如图2-22所示。
图2-22定位运行失败
脚本录制、调试完成后,还可以通过插入事务、集合点等操作来完善、增强脚本。
2.1.4完善脚本
为什么要完善增强脚本呢?
首先,为了衡量服务器的性能,需要定义事务<
Transaction)。
例如在脚本中有一个数据查询操作,为了衡量服务器执行查询操作的性能,可以把这个操作定义为一个事务。
这样在运行测试脚本时,LoadRunner运行到该事务的开始点时,就会开始计时,直到运行到该事务的结束点,计时结束。
这个事务的运行时间在测试结果中会有反映。
LoadRunner允许在脚本中插入不限数量的事务。
在方案执行期间,控制台将测量执行每个事务所用的时间。
方案运行后,可使用LoadRunner的图和报告来分析各个事务的服务器性能。
其次,使用集合点是为了衡量在加重负载的情况下服务器的性能情况。
在测试计划中,可能会要求系统能够承受多人同时提交数据,LoadRunner通过在提交数据操作前面加入集合点的方法,检查同时有多少用户运行到集合点,人数不足时,LoadRunner会命令已经到集合点的用户等待,当在集合点等待的用户达到要求容纳的人数<
如1000人)时,LoadRunner向系统提交数据。
在脚本中加入集合点后,控制台运行脚本时,可以对集合点进行策略设置,这样就可以根据实际情况在系统上模拟用户负载了。
再次,在录制过程中最好加入注释,因为在录制完脚本后看到的都是脚本代码,操作复杂的业务无法找到相应的位置进行关联或者参数化的动作,这时,注释就显得尤为重要。
最后,LoadRunner提供了很多函数,有些函数是在录制时根据不同的协议自带的函数。
其中有些函数是供手工添加的,这就要根据实际情况进行添加了。
例如脚本关联,有些变量无法实现系统自动关联,只能添加函数进行手动关联。
在录制完成的脚本中,还可以根据实际情况,添加事务、集合点、注释、函数等内容来增强脚本,进一步完善。
下面逐一进行介绍。
1.插入事务
脚本中插入事务既可以在录制过程中直接插入,也可以在脚本录制结束后经编辑插入。
建议采用在脚本的录制过程中插入事务的方法,这样不至于遗漏程序中应插入事务的操作。
在需要插入事务的操作前,通过工具栏上的“StartTransaction”<
开始事务)按钮插入事务,事务的名称最好有意义,这样在最后分析系统时,有助于发现系统的瓶颈点是否在具体的事务中。
具体的操作方法如下:
在录制Vuser脚本时,在需要定义事务的操作前面,单击“录制”工具栏上的“StartTransaction”菜单项,将打开“StartTransaction”对话框,如图2-23所示。
接着出现如图2-24所示的对话框。
图2-23插入事务开始点图2-24输入事务开始名称
在给事务起名字时,事务名必须以字母或数字开始,可以包含字母、数字或者下列字符:
!
、$、%、&
、'
、-、[、^、_、`、<
、>
、{、}、|或~。
填写好事务名称后,就可以对系统进行操作,单击“OK”接受该事务名称。
VuGen将自动在Vuser脚本中插入事务的起始标志<
“lr_start_transaction”)和终点标志<
“lr_end_transaction”)。
起点和终点之间的内容就是录制或者编写的测试事务脚本。
在录制脚本过程中,随时可以单击“录制”工具栏上的“EndTransaction”菜单项,结束录制,如图2-25所示。
图2-25插入事务结束点
此时会出现如图2-26所示的结束事务的对话框。
单击“TransactionName”下拉框的箭头获得已打开事务的列表,选择要关闭的事务。
事务的状态在默认情况下是LR_AUTO。
一般情况下,也不需要修改,除非在手工编写代码时,有可能需要手动设置事务的状态。
单击“OK”按钮接受该事务名称。
脚本中事务的代码如图2-27所示。
图2-26选择要结束事务的名称图2-27插入事务图例
当结束事务时,通过工具栏上的“EndTransaction”按钮,结束事务。
在结束列表中会显示最近定义的事务的名称,只要选择自己新建的事务的名称即可结束该事务。
这样就完成了事务的插入操作。
2.插入集合点
集合点只能在Action中插入,不能在vuser_init或vuser_end中插入。
在需要插入集合点的操作前,通过工具栏上的集合点按钮插入集合点,并在集合点的输入框中输入集合点的名称。
集合点的名称最好是有意义的名称,这样有助于在系统分析时,分析系统的瓶颈所在。
插入集合点具体的操作方法如下:
在录制Vuser脚本时,在需要插入集合点的位置,单击“录制”工具栏上的“集合点”按钮或单击“Insert”菜单下的“Rendezvous”子菜单。
将打开“Rendezvous”<
集合点)对话框,如图2-28所示。
图2-28插入集合点
接着,出现如图2-29所示的对话框。
输入该集合点的名称,注意,名称最好能够清楚地说明该集合点所完成的动作。
脚本中集合点的代码如图2-30所示。
图2-29输入集合点名称图2-30插入集合点图例