当前位置: 首页 > news >正文

jmeter 获取唯一全局变量及多线程读写的问题

一、jmeter 获取唯一ID号全局变量

在JMeter中获取唯一ID号并设置为全局变量,可以通过以下几种方法实现:

  1. 使用JMeter内置的UUID函数: JMeter提供了一个内置的函数__UUID,可以生成一个随机的UUID,这个UUID是全局唯一的。你可以在需要的地方直接使用${__UUID}来获取一个唯一的ID号。

  2. 使用BeanShell Sampler生成UUID: 如果你需要更多的自定义或者想要在生成UUID后进行一些额外的操作,可以使用BeanShell Sampler来编写Java代码生成UUID。例如:

     

    java

    import java.util.UUID;
    UUID uuid1 = UUID.randomUUID();
    vars.put("uniqueID", (uuid1.toString()).replaceAll("-",""));

    这段代码会生成一个UUID,并去除其中的破折号,然后将这个值存储在名为uniqueID的变量中。你可以在其他地方通过${uniqueID}来引用这个唯一ID号。

  3. 使用计数器和用户定义的变量: 如果你需要一个简单的递增唯一ID,可以使用JMeter的计数器。在线程组中添加一个计数器配置元件(Counter),并设置一个引用名称。然后在用户定义的变量中使用这个计数器的引用名称,例如${__counter(myCounter,1,1)}。这样每次迭代都会递增这个计数器的值,从而保证唯一性。

  4. 使用正则表达式提取器和BeanShell PostProcessor: 如果你的唯一ID是从某个响应中提取的,你可以使用正则表达式提取器来提取这个ID,然后在BeanShell PostProcessor中使用__setProperty函数将其设置为全局变量。例如:

     

    java

    String uniqueID = vars.get("extractedID");
    vars.put("globalUniqueID", uniqueID);

    这样你就可以在其他地方通过${globalUniqueID}来引用这个全局唯一的ID号。

选择以上任何一种方法,都可以在JMeter中获取并使用唯一ID号作为全局变量。根据你的具体需求和测试场景,选择最适合你的方法。

二、如何确保JMeter中的全局变量在不同线程组中保持一致?

在JMeter中,确保全局变量在不同线程组中保持一致,可以通过以下步骤实现:

  1. 设置全局变量: 在一个线程组中,使用BeanShell或JSR223元件来设置全局变量。例如,使用JSR223 PreProcessor,可以通过以下Groovy代码将一个局部变量的值设置为全局变量(Property):

     

    groovy

    // 获取局部变量值
    String localVar = vars.get("localVarName");
    log.info("Local variable value: " + localVar);
    // 在第一个线程组中设置全局变量
    props.put("globalVarName", localVar);
    log.info("Global variable set to: " + props.get("globalVarName"));

    这里,localVarName是线程组内的局部变量,globalVarName是设置的全局变量名。

  2. 获取全局变量: 在另一个线程组中,可以通过类似的代码来获取之前设置的全局变量(Property):

     

    groovy

    // 在第二个线程组中获取全局变量
    String globalVar = props.get("globalVarName");
    log.info("Global variable value: " + globalVar);
    // 将全局变量的值赋给本线程组的局部变量
    vars.put("localVarName", globalVar);

    这样,第二个线程组就可以使用第一个线程组设置的全局变量值。

  3. 使用__setProperty函数: 你还可以使用JMeter的函数__setProperty来设置全局变量,并在其他线程组中通过${__property(变量名)}来引用这个全局变量。例如,在第一个线程组中设置全局变量:

     

    java

    ${__setProperty(globalVarName, localVarValue,)}

    然后在其他线程组中引用这个全局变量:

     

    java

    ${__property(globalVarName,)}
  4. 使用BeanShell PostProcessorBeanShell Sampler: 在第一个线程组中,使用BeanShell PostProcessorBeanShell Sampler来将局部变量提升为全局变量。例如:

     

    java

    props.put("globalVarName", vars.get("localVarName"));

    然后在其他线程组中,使用BeanShell PreProcessorBeanShell Sampler来获取这个全局变量:

     

    java

    String globalVar = props.get("globalVarName");
    vars.put("localVarName", globalVar);

通过上述方法,你可以确保在JMeter的不同线程组之间共享和保持全局变量的一致性。这样,无论在哪个线程组中,都可以访问和使用这些全局变量。

三、除了全局变量,JMeter还有其他共享数据的方法吗?

在JMeter中,除了使用全局变量来共享数据之外,还可以采用以下几种方法来实现不同线程组之间的数据共享:

  1. 使用JMeter属性(Properties): JMeter的属性是全局的,可以在所有线程之间共享。可以使用__setProperty函数来设置属性,然后在其他线程组中使用${__P(propName)}来引用这个属性。这种方法适合传递静态值,如API密钥或配置参数。

  2. 使用文件转接法: 在一个线程组中将数据写入文件,然后在另一个线程组中通过CSV Data Set Config读取文件中的数据。这种方法适用于数据量较大且变化不频繁的情况。

  3. 使用JMeter的函数: JMeter提供了一些内置函数,如__groovy,可以在不同线程组之间传递数据。例如,可以在一个线程组中使用__groovy{...}函数将数据写入共享变量,然后在另一个线程组中使用相同的函数来读取这个共享变量。

  4. 使用JSR223 PostProcessors或PreProcessors: 使用Groovy或其他语言编写脚本,在脚本中使用共享的变量或属性。这种方法提供了更大的灵活性,可以在脚本中执行更复杂的逻辑来处理数据共享。

  5. 使用HTTP Cookie Manager: 如果需要在多个线程组之间共享cookie,可以使用HTTP Cookie Manager。在第一个线程组中设置cookie后,其他线程组可以引用同一个HTTP Cookie Manager来共享这些cookie。

  6. 使用JMeter的监听器(Listeners): 例如,使用View Results Tree监听器查看一个请求的响应数据,然后在另一个线程组中使用BeanShell Sampler或JSR223 Sampler来提取并使用这些数据。

  7. 使用数据库: 如果数据共享需要跨多个测试计划或长时间保持,可以考虑使用数据库来存储和读取数据。在一个测试计划中将数据写入数据库,然后在另一个测试计划中从数据库读取数据。

每种方法都有其适用场景和限制,你可以根据实际的测试需求和环境选择最合适的方法来实现数据共享。

四、 在JMeter中,我该如何处理大量共享数据的读写性能问题?

在JMeter中处理大量共享数据的读写性能问题时,可以采取以下策略来优化性能:

  1. 使用分布式集群: 当单台机器无法承载更多线程时,可以采用分布式集群的方式。通过多台机器共同承担压测任务,可以显著提高性能和数据处理能力。

  2. 优化JVM参数: 调整JMeter的JVM参数,增加堆内存和新生代内存的大小,可以提高JMeter处理大量数据的能力。例如,可以修改jmeter.bat文件中的set HEAP=-Xms2048m -Xmx2048m来增加内存分配。

  3. 使用CSV Data Set Config的共享模式: 在处理大量数据时,合理设置CSV Data Set Config的共享模式可以提高性能。例如,使用“Current thread group”模式可以让同一线程组内的线程共享数据集,减少文件的读写次数。

  4. 减少文件I/O操作: 频繁的文件读写会严重影响性能。可以通过减少文件打开次数、使用内存中的数据结构来传递数据,或者将数据存储在数据库中,通过JDBC请求来读取,以减少文件I/O操作。

  5. 使用数据库: 对于需要大量读写操作的数据,可以考虑使用数据库来存储和读取数据。JMeter可以通过JDBC Request直接与数据库交互,这样可以更有效地处理大量数据。

  6. 优化数据结构和算法: 在BeanShell或JSR223脚本中,优化数据结构和算法可以减少数据处理的时间。例如,使用更高效的数据结构来存储和检索数据。

  7. 使用缓存: 如果数据不经常变化,可以考虑使用缓存来存储热点数据,减少对后端数据源的访问压力。

  8. 监控和调优: 使用JMeter自带的监听器或更高级的工具(如Grafana与InfluxDB)进行实时监控,根据监控结果对性能进行调优。

  9. 避免使用非线程安全的元件: 在设计测试计划时,确保使用的元件是线程安全的,避免因为线程安全问题导致的性能瓶颈。

通过上述方法,可以有效提高JMeter在处理大量共享数据时的读写性能,从而更高效地进行性能测试。

相关文章:

jmeter 获取唯一全局变量及多线程读写的问题

一、jmeter 获取唯一ID号全局变量 在JMeter中获取唯一ID号并设置为全局变量,可以通过以下几种方法实现: 使用JMeter内置的UUID函数: JMeter提供了一个内置的函数__UUID,可以生成一个随机的UUID,这个UUID是全局唯一的。…...

掌握 Spring Boot 中的缓存:技术和最佳实践

缓存是一种用于将经常访问的数据临时存储在更快的存储层(通常在内存中)中的技术,以便可以更快地满足未来对该数据的请求,从而提高应用程序的性能和效率。在 Spring Boot 中,缓存是一种简单而强大的方法,可以…...

动手学深度学习10.5. 多头注意力-笔记练习(PyTorch)

本节课程地址:多头注意力代码_哔哩哔哩_bilibili 本节教材地址:10.5. 多头注意力 — 动手学深度学习 2.0.0 documentation 本节开源代码:...>d2l-zh>pytorch>chapter_multilayer-perceptrons>multihead-attention.ipynb 多头注…...

13 设计模式之外观模式(家庭影院案例)

一、什么是外观模式? 1.定义 在日常生活中,许多人喜欢通过遥控器来控制家中的电视、音响、DVD 播放器等设备。虽然这些设备各自独立工作,但遥控器提供了一个简洁的界面,让用户可以轻松地操作多个设备。而这一设计理念正是 外观模…...

单片机学习笔记 12. 定时/计数器_定时

更多单片机学习笔记:单片机学习笔记 1. 点亮一个LED灯单片机学习笔记 2. LED灯闪烁单片机学习笔记 3. LED灯流水灯单片机学习笔记 4. 蜂鸣器滴~滴~滴~单片机学习笔记 5. 数码管静态显示单片机学习笔记 6. 数码管动态显示单片机学习笔记 7. 独立键盘单片机学习笔记 8…...

Web安全基础实践

实践目标 (1)理解常用网络攻击技术的基本原理。(2)Webgoat实践下相关实验。 WebGoat WebGoat是由著名的OWASP负责维护的一个漏洞百出的J2EE Web应用程序,这些漏洞并非程序中的bug,而是故意设计用来讲授We…...

Zookeeper集群数据是如何同步的?

大家好,我是锋哥。今天分享关于【Zookeeper集群数据是如何同步的?】面试题。希望对大家有帮助; Zookeeper集群数据是如何同步的? 1000道 互联网大厂Java工程师 精选面试题-Java资源分享网 Zookeeper集群中的数据同步是通过一种称为ZAB(Zo…...

SpringCloud框架学习(第六部分:Sentinel实现熔断与限流)

目录 十四、SpringCloud Alibaba Sentinel实现熔断与限流 1.简介 2.作用 3.下载安装 4.微服务 8401 整合 Sentinel 入门案例 5.流控规则 (1)基本介绍 (2)流控模式 Ⅰ. 直接 Ⅱ. 关联 Ⅲ. 链路 (3&#xff0…...

动态规划-----路径问题

动态规划-----路径问题 下降最小路径和1:状态表示2:状态转移方程3 初始化4 填表顺序5 返回值6 代码实现 总结: 下降最小路径和 1:状态表示 假设:用dp[i][j]表示:到达[i,j]的最小路径 2:状态转…...

Rust循环引用与多线程并发

循环引用与自引用 循环引用的概念 循环引用指的是两个或多个对象之间相互持有对方的引用。在 Rust 中&#xff0c;由于所有权和生命周期的严格约束&#xff0c;直接创建循环引用通常会导致编译失败。例如&#xff1a; // 错误的循环引用示例 struct Node {next: Option<B…...

东方隐侠网安瞭望台第8期

谷歌应用商店贷款应用中的 SpyLoan 恶意软件影响 800 万安卓用户 迈克菲实验室的新研究发现&#xff0c;谷歌应用商店中有十多个恶意安卓应用被下载量总计超过 800 万次&#xff0c;这些应用包含名为 SpyLoan 的恶意软件。安全研究员费尔南多・鲁伊斯上周发布的分析报告称&…...

底部导航栏新增功能按键

场景需求&#xff1a; 在底部导航栏添加power案件&#xff0c;单击息屏&#xff0c;长按 关机 如下实现图 借此需求&#xff0c;需要掌握技能&#xff1a; 底部导航栏如何实现新增、修改、删除底部导航栏流程对底部导航栏部分样式如何修改。 比如放不下、顺序排列、坑点如…...

C++ 之弦上舞:string 类与多样字符串操作的优雅旋律

string 类的重要性及与 C 语言字符串对比 在 C 语言中&#xff0c;字符串是以 \0 结尾的字符集合&#xff0c;操作字符串需借助 C 标准库的 str 系列函数&#xff0c;但这些函数与字符串分离&#xff0c;不符合 OOP 思想&#xff0c;且底层空间管理易出错。而在 C 中&#xff0…...

centos8:Could not resolve host: mirrorlist.centos.org

【1】错误消息&#xff1a; [rootcentos211 redis-7.0.15]# yum update CentOS Stream 8 - AppStream …...

Linux 定时任务 命令解释 定时任务格式详解

目录 时间命令 修改时间和日期 定时任务格式 定时任务执行 查看定时任务进程 重启定时任务 时间命令 #查看时间 [rootlocalhost ~]# date 2021年 07月 23日 星期五 14:38:19 CST --------------------------------------- [rootlocalhost ~]# date %F 2021-07-23 -----…...

aws(学习笔记第十五课) 如何从灾难中恢复(recover)

aws(学习笔记第十五课) 如何从灾难中恢复 学习内容&#xff1a; 使用CloudWatch对服务器进行监视与恢复区域(region)&#xff0c;可用区(available zone)和子网(subnet)使用自动扩展(AutoScalingGroup) 1. 使用CloudWatch对服务器进行监视与恢复 整体架构 这里模拟Jenkins Se…...

github webhooks 实现网站自动更新

本文目录 Github Webhooks 介绍Webhooks 工作原理配置与验证应用云服务器通过 Webhook 自动部署网站实现复制私钥编写 webhook 接口Github 仓库配置 webhook以服务的形式运行 app.py Github Webhooks 介绍 Webhooks是GitHub提供的一种通知方式&#xff0c;当GitHub上发生特定事…...

【C语言】递归的内存占用过程

递归 递归是函数调用自身的一种编程技术。在C语言中&#xff0c;递归的实现会占用内存栈&#xff08;Call Stack&#xff09;&#xff0c;每次递归调用都会在栈上分配一个新的 “栈帧&#xff08;Stack Frame&#xff09;”&#xff0c;用于存储本次调用的函数局部变量、返回地…...

365天深度学习训练营-第P6周:VGG-16算法-Pytorch实现人脸识别

&#x1f368; 本文为&#x1f517;365天深度学习训练营中的学习记录博客&#x1f356; 原作者&#xff1a;K同学啊 文为「365天深度学习训练营」内部文章 参考本文所写记录性文章&#xff0c;请在文章开头带上「&#x1f449;声明」 &#x1f37a;要求&#xff1a; 保存训练过…...

企业AI助理在数据分析与决策中扮演的角色

在当今这个数据驱动的时代&#xff0c;企业每天都需要处理和分析大量的数据&#xff0c;以支持其业务决策。然而&#xff0c;面对如此庞大的数据量&#xff0c;传统的数据分析方法已经显得力不从心。幸运的是&#xff0c;随着人工智能&#xff08;AI&#xff09;技术的不断发展…...

洛谷 B2029:大象喝水 ← 圆柱体体积

【题目来源】https://www.luogu.com.cn/problem/B2029【题目描述】 一只大象口渴了&#xff0c;要喝 20 升水才能解渴&#xff0c;但现在只有一个深 h 厘米&#xff0c;底面半径为 r 厘米的小圆桶 &#xff08;h 和 r 都是整数&#xff09;。问大象至少要喝多少桶水才会解渴。 …...

go每日一题:mock打桩、defer、recovery、panic的调用顺序

题目一&#xff1a;单元测试中使用—打桩 打桩概念&#xff1a;使用A替换 原函数B&#xff0c;那么A就是打桩函数打桩原理&#xff1a;运行时&#xff0c;通过一个包&#xff0c;将内存中函数的地址替换为桩函数的地址打桩操作&#xff1a;利用Patch&#xff08;&#xff09;函…...

STM32F103 HSE时钟倍频以及设置频率函数(新手向,本人也是新手)

HSE_SetSysCLK是野火教程里的,不懂的去这 16-RCC&#xff08;第3节&#xff09;使用HSE配置系统时钟并使用MCO输出监控系统时钟_哔哩哔哩_bilibili HSE_AutoSetHSE的算法部分是自己写的,用了一个转接数组。C语言不支持bool所以自己定义了一个boolK代替bool。 AutoHSE.h: /**…...

renderExtraFooter 添加本周,本月,本年

在 Ant Design Vue 中&#xff0c;a-date-picker 组件提供了一个 renderExtraFooter 属性&#xff0c;可以用来渲染额外的页脚内容。你可以利用这个属性来添加“本周”、“本月”和“本年”的按钮。下面是如何在 Vue 2 项目中实现这一功能的具体步骤&#xff1a; 1.确保安装了…...

SprinBoot整合KafKa的使用(详解)

前言 1. 高吞吐量&#xff08;High Throughput&#xff09; Kafka 设计的一个核心特性是高吞吐量。它能够每秒处理百万级别的消息&#xff0c;适合需要高频次、低延迟消息传递的场景。即使在大规模分布式环境下&#xff0c;它也能保持很高的吞吐量和性能&#xff0c;支持低延…...

【机器学习】CatBoost 模型实践:回归与分类的全流程解析

一. 引言 本篇博客首发于掘金 https://juejin.cn/post/7441027173430018067。 PS&#xff1a;转载自己的文章也算原创吧。 在机器学习领域&#xff0c;CatBoost 是一款强大的梯度提升框架&#xff0c;特别适合处理带有类别特征的数据。本篇博客以脱敏后的保险数据集为例&#x…...

PyTorch 实现动态输入

使用 PyTorch 实现动态输入&#xff1a;支持训练和推理输入维度不一致的 CNN 和 LSTM/GRU 模型 在深度学习中&#xff0c;处理不同大小的输入数据是一个常见的挑战。许多实际应用需要模型能够灵活地处理可变长度的输入。本文将介绍如何使用 PyTorch 实现支持动态输入的 CNN 和…...

【Linux相关】查看conda路径和conda和cudnn版本、安装cudnn、cuDNN无需登录官方下载链接

【Linux相关】 查看conda路径和conda和cudnn版本 安装cudnn cuDNN无需登录官方下载链接 文章目录 1. 查看信息1.1 查看 Conda 路径1.2 查看 Conda 版本1.3 查看 cuDNN 版本1.4 总结 2. 安装cudnn2.1 安装cudnn步骤2.2 cuDNN无需登录官方下载链接 1. 查看信息 查看Conda 路径、C…...

基于Java Springboot环境保护生活App且微信小程序

一、作品包含 源码数据库设计文档万字PPT全套环境和工具资源部署教程 二、项目技术 前端技术&#xff1a;Html、Css、Js、Vue、Element-ui 数据库&#xff1a;MySQL 后端技术&#xff1a;Java、Spring Boot、MyBatis 三、运行环境 开发工具&#xff1a;IDEA/eclipse 微信…...

简单的springboot使用sse功能

什么是sse? 1、SSE 是Server-Sent Events&#xff08;服务器发送事件&#xff09; 2、SSE是一种允许服务器主动向客户端推送实时更新的技术。 3、它基于HTTP协议&#xff0c;并使用了其长连接特性&#xff0c;在客户端与服务器之间建立一条持久化的连接。 通过这条连接&am…...