性能测试基础---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块大小>=调用次数。
且
参数值的数量>=虚拟用户数×块大小
性能测试基础---LR参数化相关的更多相关文章
- 性能测试基础---jmeter参数化、关联、事物、检查的等
·Jmeter脚本增强·性能测试的脚本增强技术:参数化.关联.事务.检查点.思考时间和集合点. ·参数化:在Jmeter中,实现参数化的方式很多.本质上来说,参数化的实现方式有两种:·文件方式:一般建 ...
- 性能测试基础---LR场景设置
·场景设置. 性能测试场景依托于性能测试脚本,但是又独立于脚本. 所谓场景(scenario),就是用来模拟多用户运行性能测试脚本的情形,是来源于我们对于业务场景的分析的. 性能测试对于业务场景的分析 ...
- 性能测试基础---LR关联
·什么时候需要做关联?一般来说,在脚本运行出错的时候,我们就可能需要进行关联处理. ·脚本出错分为两种情况: ·直接回放出错(失败).通常来说,如果录制成功,回放失败,排除数据的唯一性约束之后,那就必 ...
- 性能测试基础---LR运行设置
·LR的运行时设置(Runtime settings): ·Run Logic:该选项是用来控制脚本的真正的运行逻辑. ·该选项会把脚本中的函数分别放入三个运行模块中:Init.Run.End ·默认 ...
- 性能测试基础---LR关联2
·LR中的关联函数详解.在LR中,用于关联的函数一般有以下四个:web_reg_save_param 是通过字符串查找的方式来查找获取数据.web_reg_save_param_ex 是通过字符串查找 ...
- lr参数化——500户并发迭代1次 循环取5条数据
lr参数化——500户并发迭代1次 循环取5条数据 比如vuser1.vuser2.vuser3..........,vuser500 shuju1,shuju2,shuju3,shuju4,shuj ...
- 第一天上午——HTML网页基础知识以及相关内容
今天上午学习了HTML基础知识以及相关内容,还有DW的基本使用方法. HTML(HyperText Markup Language):超文本标记语言,超文本:网页中除了包含文本文字之外,还包含了图片, ...
- 背水一战 Windows 10 (76) - 控件(控件基类): Control - 基础知识, 焦点相关, 运行时获取 ControlTemplate 和 DataTemplate 中的元素
[源码下载] 背水一战 Windows 10 (76) - 控件(控件基类): Control - 基础知识, 焦点相关, 运行时获取 ControlTemplate 和 DataTemplate 中 ...
- lr参数化取值与连接数据库
TXT文本,EXCEL表格以及数据库中的表都可以作为参数的数据集载体,LR都是支持的. 特别提醒: 1.在形成数据池之后,数据库中的数据变化不会影响数据池中的数据. 2.数据文件一定要以一个空行结束, ...
随机推荐
- Android Studio 之 控件基础知识
1. TextView 和 EditText 控件常用属性 android:layout_width="match_parent" 宽度与父控件一样宽 android:layou ...
- dockerfile 的问题 FROM alpine:3.8 temporary error (try again later)
FROM alpine:3.8 apk add xxx安装软件 fetch http://dl-cdn.alpinelinux.org/alpine/v3.8/main/x86_64/APKINDEX ...
- concurrent(五)同步辅助器CountDownLatch & 源码分析
参考文档: https://blog.csdn.net/zxdfc/article/details/52752803 简介 CountDownLatch是一个同步辅助类.允许一个或多个线程等待其他线程 ...
- Solr7.x学习(3)-创建core并使用分词器
1.创建core文件夹 ck /usr/local/solr-7.7.2/server/solr mkdir first_core cp -r configsets/_default/* first_ ...
- recttransform
转载自https://www.jianshu.com/p/4592bf809c8b 1.Anchor:子物体和父物体联系的桥梁,Anchors是由两个点确定的,他们就是AnchorMin以及Ancho ...
- 设置KAFKA
让我们继续下载并设置Kafka,启动zookeeper,集群,生产者和消费者. 要下载Kafka,请参阅此链接 http://kafka.apache.org/downloads.html 下载 ...
- FindWindow和FindWindowEx函数使用
FindWindow( lpClassName, {窗口的类名} lpWindowName: PChar {窗口的标题} ): HWND; {返回窗口的 ...
- 冒泡排序法vs快速排序法
闲着没事,想思考一下两种排序法的直观对比,写了个小程序,代码如下,分析见后面: class Program { static DateTime t1, t2; static TimeSpan ts1, ...
- 根据语义来选择:value-like传副本, pointer-like传引用
★ (一个成员)变量的 创建.初始化.赋值 “默认值”:内置类型的局部变量.内置类型的成员变量(未设置=initval;) 没有默认值! 若创建时不指定值,则不进行初始化.则其值未定义!!! “指定 ...
- keras学习入门一
基本概念 1. 张量 tensor 所有的数据类型都可以看成是张量,可以看成是向量,矩阵在推广 张量的阶,有时候也叫维度,或是轴(axis) 0阶张量如 [] ,5 也叫做标量 1阶张量 如 [ 1, ...