性能测试基础---LR参数化相关
性能测试脚本的增强:
·参数化
·关联
·事务
·检查点
·思考时间
·集合点
·参数化:模拟不同用户的不同请求。
·为什么要做参数化?
·功能:通常来说,系统的某些业务数据具有唯一性的要求。
·性能:一般来说,如果系统的后端(服务器端)对于业务提供了缓存机制,则要考虑参数化。
PS:一般来说,查询类的业务都会通过缓存机制来提升服务器端的性能的。
从模拟的真实度来说,缓存和非缓存数据的比例越接近真实线上数据越好。
·参数化的实现操作。
在LR中,参数化的实现方式很多,但是从本质上来说,只需要保证两点:
·参数存在并且有值。
·脚本中对参数进行了调用。
在LR中,参数调用的格式一般为:“{参数名}”。
·参数化的实现方式:
在LR中,参数的类型有很多种,所以实现方式也有很多。但是从本质上来说,参数的实现方式就是两种:
·函数方式:通过LR内置的函数去实现参数值的生成。
·文件方式:通过读取数据文件(source)的方式来实现。
·参数和参数文件是多对一的关系。
·一个参数文件中可以存放多列值。
·一个参数只能读取一个参数文件中的某一列值。
·参数化的注意事项:
·如果用记事本编辑参数文件,则要保证最后的有效数据之后有且只有一个回车。
·一般来说,只有用户输入或者选择的数据我们才会做参数化处理。
·参数化一般只是针对用户输入或者所选择的值。
·参数值本身要符合业务功能的要求。
主要是:长度、类型、格式和合法性
·参数化要注意参数的取值方式。
·First data选项:该选项会决定参数值从第几个开始读取使用,默认是从第一行开始。GUI界面只是一个显示的效果,并不会影响参数值的使用。
·参数的取值方式。
在LR中,参数的取值方式是由两个选项组合决定的。
·Update value on:该选项所设置的是参数获取变更参数值的时机。
该选项有三种可选的时机:
·each Iteration:每次迭代,是指每一次迭代开始的时候,参数就会去变更参数值。在下一次迭代开始之前,不论该参数是否被调用、调用一次还是多次,该参数的值都不会改变。
该方式下,参数值的变更和迭代有关,和调用无关。
参数值的变更次数等于迭代次数。
·each Occurrence:每次出现,所谓出现就是指参数被调用。是指每一次参数被调用之前,参数都会去变更参数值。
该方式下,参数值的变更和调用有关,和迭代无关。
参数值的变更次数等于调用次数。
·Once:仅一次,是指参数第一次被调用时,参数就会去获取一个参数值。在虚拟用户的生命周期中,该参数的值不再发生变更。
·Select next row:该选项所设置的是参数获取变更参数值的方式。
该选项有四种可选的方式:
·Sequential:顺序取值。
·Random:随机取值。
·Unique:唯一取值。
在LR中,对于唯一的实现,采取的是分配的方式。先分配再顺序取值。
将所有的参数值按照块大小(用户设置)依次一块一块的批量分配给虚拟用户,然后每个虚拟用户在自己所分配到的数据块中按顺序读取参数值。
·Same line as XXX:只有当一个脚本中出现两个及两个以上的文件类型的参数时,才会有该选项。
作用:如果参数A选择了Same line as 参数B,则表示每一次调用参数A时,参数A都会使用和参数B当前的值相同行号的参数值。
这就意味着通过该选项,可以将两个参数实现参数值的一一对应关系(前提是用户自身要维护好参数文件中的数据)。
PS:该选项不参与和Update选项的组合。
综上可知,在LR中,参数的取值方式总计有:
3×3+1=10种。
示例: User1 User2
S+I AA|BB AA|BB
S+O AB|CD AB|CD
S+Once AA|AA AA|AA
R+I XX|YY XX|YY
R+O R1R2|R3R4 R1R2|R3R4
R+Once XX|XX XX|XX
取值方式总结:
·如果某个参数在一次迭代中调用次数超过两次,则需要考虑每次迭代和每次出现的区别。
·随机取值和顺序取值本质上没有任何区别。
·顺序取值和唯一取值都无法满足业务的唯一性要求,只能使用unique方式。
Unique方式的选项:
·When out of values:所谓的out of values是指参数值的变更次数超过所分配到的参数值的数量,该选项就是用来决定下一步继续怎么操作,有三种可选方式:
·Abort Vuser:中止虚拟用户。
·Continue with last value:继续执行,但是使用最后一次的值。
·Continue with cycle manner:继续执行,循环使用自己所分配到的值。
PS:选择Abort可以保证全局的唯一性。
选择Continue则意味着用户放弃了唯一的诉求,而只是保留了分配的效果。即实现了虚拟用户之间的唯一(不同)。
·Allocate:用来设置块大小,方式有两种,自动和手动。
·自动方式:仅适用于每次迭代,作用是块大小自动等于run logic中的迭代次数。
·手动:手动指定块大小。
PS:一般来说,要保证用户不error,则:
参数值的数量>=(虚拟用户数-1)×块大小+1
要保证每一次都唯一,则:
块大小>=迭代次数or块大小>=调用次数。
且
参数值的数量>=虚拟用户数×块大小
最新文章
- SHELL编写NGINX自动部署脚本
- Java关键字介绍
- HDU 1372 Knight Moves (bfs)
- [moka同学笔记]百度编辑器Ueditor自动换行,添加<;p>;的问题(摘录)
- IE11打不开网页, 所有菜单都被禁用了。
- js编程风格
- 7. Shell 函数
- POJ2524并查集水题
- PHP 5 Timezones
- ready
- css 技巧 (持续更新)
- python numpy模块使用笔记(更新)
- systemd service 设置limit,不生效问题
- php的explode()和implode()方法
- Linux shell下30个有趣的命令
- SpagoBI 教程 Lesson 3: Highchart Dashboards
- 前端基础-CSS是什么?
- ctsc&;apio2018八日游
- python No migrations to apply
- Http服务端
热门文章
- nginx配置神器
- 转 史上最详细的Hadoop环境搭建
- HTTP、HTTP2.0、SPDY、HTTPS 你应该知道的一些事
- Django 分析(一)Requst、Middleware 和 Response 数据流
- Golang(二)基本概念
- Qt应用程序主窗口之二:拖放操作与打印文档
- Oracle &#39;no privileges on tablespace 表空间名称&#39; 问题解决
- Java 中常见的 final 类
- C语言结构体的“继承”
- DispatcherServlet 是 spring 网络模块的核心