Jmeter系列(45)- 详解 Jmeter 跨线程组取参数值的方法,免代码!
如果你想从头学习Jmeter,可以看看这个系列的文章哦
https://www.cnblogs.com/poloyy/category/1746599.html
前言
- 用过 Jmeter 的同学应该都知道,Jmeter 不支持跨线程传递参数
- 哎,那我想跨线程传递参数,要咋整呢?别急,接下来我们就来讲解如何不使用代码就可以解决此问题
- 官方也有正式说明,所以这并不是 Bug 哦

一定要通过 BeanShell 去跨线程组传递参数吗?
- 通过百度搜索:Jmeter 跨线程组传递参数
- 会看到很多文章都是通过 BeanShell 写代码去实现的
- 这对于代码小白极其不友好!
- 所以这篇文章将教会大家如何不通过写代码去实现跨线程传递参数!
定义属性法
思路
在Jmeter 中,属性时全局的,可以动态设置;但变量是每个线程独有的,所以通过设置属性可以实现跨线程传参
测试计划结构树

- 第一步:添加了三个线程组
- 登录需要注册接口返回的手机号,获取订单列表需要登录接口返回的token,均需要跨线程组传参
注册接口的 Json 提取器

第二步:通过提取器(json、正则、xpath),提取需要跨线程组传递的值
注册接口的 BeanShell 后置处理器

第三步
- 添加一个 BeanShell 后置处理器
- 添加一个 ${__setProperty()} 函数,按照图片说明写变量名
登录接口的请求体

第四步
- 引用第三步在 BeanShell 后置处理器设置的变量名(phone)
- 通过 ${__P()} 来引用变量名
第五步
运行脚本!就能发现可以跨线程组传递参数啦
登录接口的 BeanShell 后置处理器

一样的步骤,添加 token 属性
获取订单列表的请求参数

获取 token 属性
查看属性显示

可以通过属性显示这个控件查看我们在 BeanShell 设置的两个属性和对应的值(phone、token)
拓展一下
如果想在一个 BeanShell 设置多个属性,可以这样写哦

每个函数之间用 ; 分开即可(建议分)
然后可以在属性显示中查看两个不同的属性都会生效

文件在转接法
思路
一个线程组运行结果,存储到文件,另一个线程组,通过csv读取文件,然后再提取文件中需要的值,作为变量输入
线程组结构树

第一步
- 添加两个线程组,写好接口
- 注册接口后面添加保存响应文件(在监听器下面)
注册接口下的保存响应到文件

第二步
- 设置保存文件的路径和文件名
- 记得选项跟着我勾哦,不然生成的文件名就不是你指定的(test.json)
CSV 数据文件设置

第三步
- 在第二个线程组添加 CSV 数据文件设置
- 文件名:设置刚刚保存的路径
- 分隔符:json 数据建议填\t ,可以根据自己的数据结构来定,能取出完整的数据就好了
看看read_phone 的数据是啥

一个 json 数据
登录接口的请求体

第四步:接口正常引用 json 提取器的变量即可
登录线程组的结果树

这里需要注意一点
在真正的请求取样器前面需要加一个调试取样器,上图可以看到第一个取样器无法取倒变量,因为提取器都是后置处理器
所以第二个线程组元件的执行顺序会是
- csv 数据文件设置
- 调试取样器
- json 提取器
- 登录请求
Jmeter系列(45)- 详解 Jmeter 跨线程组取参数值的方法,免代码!的更多相关文章
- 【柠檬班】史上最简单的Jmeter跨线程组取参数值的两种办法(不写代码)【原创】
如果你工作中已经在用jmeter做接口测试,或性能测试了,你可能会遇到一个麻烦,哪就是jmeter的变量值不能跨线程组传递. 看,官方就已经给出了解释.这个不是jmeter的缺陷,这是jmeter ...
- 解决Jmeter跨线程组取参数值难题!(还没试)
来源 https://mp.weixin.qq.com/s/q7ArxwnX1sOfa9tfHouSBQ 如果你工作中已经在用jmeter做接口测试,或性能测试了,你可能会遇到一个麻烦. 那就是j ...
- JMeter接口测试-跨线程组取参数值的两种方法
前言 如果你工作中已经在用jmeter做接口测试,或性能测试了,你可能会遇到一个麻烦.那就是jmeter的变量值不能跨线程组传递.如果变量在开始测试之前已经确定了,我们可以用参数化关联就可以实现. 但 ...
- Jmeter系列(10)- 阶梯加压线程组Stepping Thread Group详解
如果你想从头学习Jmeter,可以看看这个系列的文章哦 https://www.cnblogs.com/poloyy/category/1746599.html 前言 Stepping Thread ...
- 接口测试工具-Jmeter使用笔记(九:跨线程组传递变量)
使用场景: 请求API需要授权令牌,但是授权令牌只需要获取一次,即可调用服务器上其他业务接口. 所以我想要把授权操作放在单独的一个线程,业务流放在其他线程. 这就需要我把从授权线程获取的令牌传入业务流 ...
- JMeter学习笔记--详解JMeter配置元件
JMeter配置元件可以用来初始化默认值和变量,以便后续采样器使用.将在其作用域的初始化阶段处理. CSV Data Set Config:被用来从文件中读取数据,并将它们拆分后存储到变量中,适合处理 ...
- JMeter学习笔记--详解JMeter逻辑控制器
JMeter使用逻辑控制器来决定采样器的处理顺序 简单控制器(Simple Controller):存储设备(将某些采样器归组) 循环控制器(Loop Controller:设置循环次数 仅一次控制器 ...
- JMeter学习笔记--详解JMeter定时器
定时器的处理优先于同一作用域内的采样器,如果在同一作用域内有多个定时器,那么所有的定时器都会在每个采样器之前处理. 若定时器所在作用域内无采样器,那么定时器不会被处理 固定定时器,每个线程在请求之间间 ...
- jmeter全局变量配置:将token运用到全局(跨线程组使用变量)
请注意元器件的执行顺序: 请将提取token的配置原件放在设置全局变量的配置元器件前面(本来是一个超级马虎的人,真是俗称“方脑壳”啊) 1.获取登录后的token(提取可以用json path Ext ...
随机推荐
- 痞子衡嵌入式:恩智浦i.MX RT1xxx系列MCU启动那些事(11.0)- FlexSPI NOR启动时间(RT1170)
大家好,我是痞子衡,是正经搞技术的痞子.今天痞子衡给大家介绍的是恩智浦i.MX RT1170 FlexSPI NOR启动时间. 痞子衡刚刚拿到i.MXRT1170 B0版本的芯片,迫不及待地在上面跑了 ...
- 检查*.ldf为何这么大
testdb,只是个测试用文件,备份时突然发现*.ldf怎么这么大,当硬盘不要花银子买啊......--可随意删除...,有空再检查,累了休息... 如批量生成数据.或导入那个来自MySQL的Empl ...
- [.NET 开源] 高性能的 Swifter.MessagePack 已发布,并附带新版本的 Swifter.Json 和 Swifter.Data。
抱歉各位朋友,由于各种私事公事,本应该在 19 年底发布的 Swifter.MessagePack 库延迟了这么久才发布,我深感抱歉. MsgPack 简介 MsgPack 一种非常轻巧的二进制数据交 ...
- 数据库(mysql)基础操作
DDL(数据定义语言)------>建库,建表 DML(数据操作语言)------>对表中的记录操作增删改查 DQL(数据查询语言)------>对表中的查询操作 DCL(数据控制语 ...
- 基于docker-compose部署jumpserver
基于docker-compose部署jumpserver 组件说明 Jumpserver 为管理后台, 管理员可以通过 Web 页面进行资产管理.用户管理.资产授权等操作, 用户可以通过 Web 页面 ...
- 阿里P7终于讲完了JDK+Spring+mybatis+Dubbo+SpringMvc+Netty源码
前言 这里普及一下,每个公司都有职别定级系统,阿里也是,技术岗以 P 定级,一般校招 P5, 社招 P6 起.其实阅读源码也是有很多诀窍的,这里分享几点心得: 首先要会用.你要知道这个库是干什么的,掌 ...
- 键盘侠Linux教程(四)| 常用命令
前言 Linux命令并不可怕,只要熟悉日常的操作命令即可,其他不熟悉的命令,需要用到的时候可以查阅资料,熟能生巧. Linux常用操作命令 命令的基本格式 命令的提示符 [root@localhost ...
- nuget 包是如何还原包的
nuget 是如何还原包的 Intro 一直以来从来都是用 nuget 包,最近想折腾一个东西,需要自己搞一个 nuget 包的解析,用户指定 nuget 包的名称和版本,然后去解析对应的 nuget ...
- postman写测试用例
接口测试引用聚合数据(手机号码归属地)接口 1,点击postman左上角红框+New Collection来创建文件,用来存放测试用例 文件名为号码归属地查询(随意) 2,右击文件选择Add Req ...
- WARN deploy.SparkSubmit$$anon$2: Failed to load org.apache.spark.examples.sql.streaming.StructuredNetworkWordCount.
前言 今天运行Spark Structured Streaming官网的如下 ./bin/run-example org.apache.spark.examples.sql.streaming.Str ...