• 全面jmeter逻辑控制器案例详解


    逻辑控制器作用:

    (1)控制测试计划或者线程组中节点的逻辑执行顺序。

    (2)对测试计划或者线程组中的脚本进行分组、方便jmeter统计执行结果以及脚本运行时的控制等。jmeter中逻辑控制器(Logic Controllers)的作用域只对其子节点的sampler有效,作用是控制采样器的执行顺序。

    一、简单控制器(Simple Controller)

    简单控制器,顾名思义就是功能比较简单,可以理解为一个文件夹,或起到分组作用。在脚本众多的时候,可以定义多个简单控制,分别存放不同的脚本请求。

     

     二、循环控制器(Loop Controller)

    作用:指定其子节点运行的次数,可以使用具体的数值,也可以使用变量。

    1、Forever选项:勾选上这一项表示一直循环下去

    2、如果同时设置了线程组的循环次数和循环控制器的循环次数,那循环控制器的子节点运行的次数为两个数值相乘的结果。

    线程组并发数设置2,循环次数2次,循环控制器设置循环3次,则一共执行2×2×3=12次;

     三、仅一次控制器:

    仅一次控制器,在循环执行中对该控制器下的请求进行执行一次,然后在接下来的循环执行中将会跳过该控制器下的所有请求。

    在进行登录的测试中,可以考虑将登录请求放在仅一次控制中,这样登录请求只执行一次。在并发查询时,可能会使用到仅一次控制器,在并发查询时,我们只需要登录请求执行一次即可。Jmeter中的仅一次控制器相当于loadrunner中的init的初始化action。
    线程数设置循环3次

    楼清接口不在控制器内,会执行3次,而灰浆接口执行1次;

     

    四、随机控制器

    线程组循环设置1时,每运行一次会随机地运行1个sampler

    线程组循环设置2时,每运行一次会随机地运行2个sampler

     

     五、随机顺序控制器

    随机顺序控制器下的sampler添加3个

    随机顺序控制器执行一次,会随机打乱执行它下面的所有的sampler一次

     线程组循环设置1时,每运行1次会运行3个sampler,顺序打乱随机

     线程组循环设置2时,每运行1次会运行3个sampler,循环2次,共计6个sampler,顺序打乱随机

     六、交替控制器

    循环控制器(设置循环7次)——交替控制器,下面添加3个sampler 

    循环时顺序迭代交替控制器下的sampler 

     线程组1循环设置1次,循环控制器设置7次,顺序循环7次sampler  1231231

    七、Runtime控制器

     Runtime(seconds):设置为N,则其下所有节点的运行时间为N秒。其下所有节点,跑完一轮,耗费时间小于N秒,此时,再从头执行一边,直到执行时间等于N,跳出控制器。

     八、如果(If)控制器

    if控制器条件满足,执行控制器下的Sampler;不满足、不填写条件,则不执行;

    1.Interpret Condition as Variable Expression?:这个选项勾选了之后,条件中,如果写“${a}" == "${b}”(及时变量a和变量b的值相等,也不会执行)。这个地方,就必须要填写一个返回True的表达式,比如${JMeterThread.last_sample_ok},这样的表达式。

    2.Evaluate for all children:假如这个控制器下面,有3个HTTP请求。如果需要在执行每个HTTP请求前,进行判断是否满足控制器中的条件,则需要勾选该复选框。

    debug Sampler 响应数据 JMeterThread.last_sample_ok=true

    条件设置为${JMeterThread.last_sample_ok},这是判断boolean类型,true执行,false不执行。

     条件设置为"${JMeterThread.last_sample_ok}"=="AAA",成立执行,不成立不执行

     

     九、While控制器

     执行该控制器下所有节点,直到它的条件被判断为false,才会跳出控制器,执行后续sampler;

     

    1、哪些条件会导致While Controller控制器跳出循环退出?

    成功的sampler在前面 失败的sampler在后面 执行到fail会跳出循环
    条件中的方法或者变量为false Condition ${BooleanValue}

    条件不满足了 Condition "${BooleanValue}"=="AAA"
    这个控制器下的sampler执行结果失败

    2、哪些条件会导致While Controller控制器下sampler一直循环执行?

    Condition什么都不写(会一直循环执行 知道执行到有fail跳出循环)

    失败的sampler在前面 成功的sampler在后面 这种情况会一直执行死循环

    Condition写LAST(会一直循环执行 知道执行到有fail跳出循环)Condition LAST

     十、While控制器

    Switch Value可以填什么?

    1.什么都不填写:此时,执行第一个节点 

    2.填写数字:填写N,则会执行这个控制器下面的第N+1个Sampler 

     

     3.填写字符:会进行sampler名称字符串全匹配     填写     sampler名称全匹配 

     十一、遍历循环控制器-ForEach 控制器

    作用:ForEach控制器一般和用户自定义变量一起使用,其在用户自定义变量中读取一系列相关的变量。该控制器下的采样器或控制器都会被执行一次或多次,每次读取不同的变量值(多个变量执行多次)

    示例:1、创建不同权限的用户,账号用随机变量创建,类型0和1用自定义变量

    输入变量前缀:在其中输入需要遍历的用户参数(User Parameter)

    Start index for loop(exclusive):循环指数开始(唯一)→ 遍历查询的变量范围,开始的值(这里如果不填写,默认从1开始,如果没有1开始的变量,执行时会报错)

    End index for loop(inclusive):循环指数结束(包含)→ 遍历查询的变量范围,结束的值

    输出变量名称:将遍历查询到的符合条件的用户参数赋值给输入变量(Vname),然后就可以在控制器下的取样器使用,格式为${输出变量名}

    Add”_”before number:输入变量名称中是否使用“_”进行间隔

    PS:这个控制器一般配合配置元件→ 正则表达式提取器来一起使用,可对页面上的某些元素进行重复处理。

     

     十二、事务控制器

    作用:事务控制器会生产一个额外的采样器,用来统计该控制器子结点的所有时间。

    应用场景: 完成一个完整的页面请求或一组请求或一组测试场景(多线程时是顺序执行的)

     参数:

    Generate parent sample:勾选后,所有的结果将在父结点中展示(选中这个参数结果展示如下图红框,否则显示为下图蓝框)

    Include duration of timer and pre-post processors in generated sample:选中这一项会统计定时器(timer)的时间,否则只统计采样器(sample)的时间
    1、事务下有多个取样器,其中一个取样器请求失败,这个事务就失败了

     

    十三、 吞吐量控制器

    1、介绍

    吞吐量控制器(Throughput Controller)用来控制其下元件的执行次数,并无控制吞吐量的功能。
    作用:控制其下的子节点的执行次数与负载比例分配;

    吞吐量控制器字段介绍:

    Total Executions:执行百分比(1-100)

    percent Executions:执行数量

    Per User:线程数,当选Total Executions时,是线程数;当选percent Executions时,是线程数*循环次数

     2、添加吞吐量控制器(线程组-逻辑控制器-吞吐量控制器)

     

     3、场景实战

    场景一:选Total Executions,设置吞吐量数量

    线程组-线程数4,循环次数2;灰浆吞吐量控制器设置-选Total Executions,吞吐量5;楼清吞吐量控制器设置-选Total Executions,吞吐量9

    分析:整个线程组会执行4×2=8个,灰浆执行5个,楼清设置9是超过最大值8,所以会执行最大值8;

     查看结果,灰浆5个,楼清8个

     场景二:选percent Executions,设置比例

    线程组-线程数5,循环次数2;灰浆吞吐量控制器设置-选percent Executions,吞吐量30;楼清吞吐量控制器设置-选percent Executions,吞吐量70

    分析:总线程组会执行5×2=10个,灰浆占比30%,执行3个;楼清占比70%,执行7个

     查看结果:灰浆执行3个,楼清执行7个

     场景三:选Total Executions,吞吐量不填,勾选Per User,执行数=线程数

    1、线程组-线程数5,循环次数2;灰浆吞吐量控制器设置-选percent Executions,吞吐量30;楼清吞吐量控制器设置-选Total Executions,吞吐量不填,勾选Per User

    分析:则灰浆执行3个,楼清执行线程数5个

    场景四:选percent Executions,吞吐量不填,勾选Per User,执行数=线程数 *循环次数

    线程组-线程数5,循环次数2;灰浆吞吐量控制器设置-选percent Executions,吞吐量30;楼清吞吐量控制器设置-选percent Executions,吞吐量不填,勾选Per User

     分析:则灰浆执行3个,楼清执行线程数10个

     

  • 相关阅读:
    bzoj 2002 [Hnoi2010]Bounce 弹飞绵羊
    【无图慎入】Link Cut Tree 总结
    cogs1889 [SDOI2008]Cave 洞穴勘测 link-cut tree
    Codeforces Round #452 (Div. 2)
    【正经向】NOIP2017烤后总结
    cogs1772 [国家集训队2010]小Z的袜子
    noip2017普及题解
    noip2017 TG 游记
    noip2017 PJ AK记
    jzoj5341 捕老鼠
  • 原文地址:https://www.cnblogs.com/datacenter/p/15958719.html
Copyright © 2020-2023  润新知