Jmeter并发线程场景下共享变量错乱问题解决

  • 问题复现

    • 问题描述

    使用IF控制器获取前一个请求的后置脚本中设置的全局变量->并发线程下通过vars.get获取变量时,第一个线程和第二个线程获取的变量值一样->导致不同基础数据的请求入参一样

    • 方法如下:

      vars.put("shoppingCartIdList", shoppingCartIdList.toString());
      //设置标志位,用于后续接口是否触发请求
      vars.put(isSend, "true");

    • if控制器的设置

    • 同一个线程循环时出现获取变量混乱的情况

      第一个线程请求入参正确

      第二个请求入参是第一个的入参

      两者的入参一样。

  • 分析原因

    • 设置全局变量的方式不对,需要用AtomicReference类进行线程的安全操作,设置方法如下:

      复制代码
      AtomicReference<JSONArray> threadLocalShoppingCartIdList = new AtomicReference<>(shoppingCartIdList);
      vars.putObject("shoppingCartIdList", threadLocalShoppingCartIdList);
      vars.putObject(isSend, "true");

    AtomicReference说明:

    复制代码
    - 原子操作:AtomicReference 提供了原子性的引用更新操作。通过CAS

    (Compare And Swap)算法,可以确保对引用对象的原子操作,避免了使用锁

    带来的性能开销。

    • 共享变量:AtomicReference 适用于需要在多个线程之间共享同一个引用对象的
      场景,可以安全地对引用对象进行读取和更新操作。

    • 线程间通信:AtomicReference 主要用于实现在多线程环境下对共享变量的原子
      操作,是一种并发编程的工具。

    • 设置安全的变量后,如何取出?方法如下:

      AtomicReference<JSONArray> shoppingCartIdListRef = new AtomicReference<>(new JSONArray(vars.get("shoppingCartIdList")));
      JSONArray shoppingCartIdList = shoppingCartIdListRef.get();

通过AtomicReference方法可以保障线程并发场景下使用的全局变量设置方式在共享变量间每个线程各自取自己的,不会出现变量混乱的情况。


更多测试技术分享、学习资源以及一些其他福利可关注公众号:【Coding测试】获取:

相关推荐
se-tester2 天前
性能测试(Performance Testing)、压力测试(Stress Testing)和 负载测试(Load Testing)三者的区别
性能测试
Felven2 天前
国产沐创N20 100G网卡性能测试
linux·性能测试·国产100g网卡·沐创
七夜zippoe5 天前
性能测试实战:Locust负载测试框架深度指南
分布式·python·性能测试·locust·性能基准
七夜zippoe7 天前
属性测试革命:Hypothesis框架深度实战指南
python·性能测试·数据驱动·hypothesis·状态机测试
xcLeigh8 天前
基于 IoT-benchmark 的时序数据库性能测试实战:从安装到结果分析
数据库·物联网·性能测试·时序数据库·iotdb
Felven16 天前
corundum 40G开源网卡测试结果
fpga开发·性能测试·dds·开源网卡·mqnic
dawdo22217 天前
自己动手从头开始编写LLM推理引擎(11)-xLLM的benchmark实现
llm·transformer·性能测试·qwen·benchmark·推理引擎
Felven18 天前
D3000平台DDR4Stream单核性能高于多核性能情况说明
性能测试·ddr4·飞腾·d3000
玉梅小洋23 天前
iperf 网络性能测试完整指南(含多服务端测试)
网络·测试工具·性能测试·iperf
张永清24 天前
每周读书与学习->JMeter性能测试脚本编写实战(四)-利用JMeter对MySQL数据库查询进行性能测试
性能测试·性能调优·jmeter性能测试·性能分析·性能诊断