• 基于 JMeter API 开发性能测试平台


    背景:

    JMeter 是一个功能强大的性能测试工具,若开发一个性能测试平台,用它作为底层执行引擎在合适不过。如要使用其API,就不得不对JMeter 整个执行流程,常见的类有清楚的了解。

    常用的 JMeter 类和功能的解释:

    TestPlan 类:代表一个测试计划,它是性能测试的顶级元素。您可以使用它来设置全局的测试属性,如测试名称、线程组、监听器等。

    ThreadGroup 类:代表线程组,它定义了并发执行的线程数、启动延迟时间、循环次数等。线程组是性能测试的基本单位,所有的线程都在线程组内执行。

    LoopController 类:代表循环控制器,它定义了循环的次数或条件。可以将循环控制器添加到线程组中,以便在每个线程中执行多次循环。

    HTTPSampler 类:代表 HTTP 请求采样器,用于发送 HTTP 请求。您可以设置请求的 URL、方法(GET、POST 等)、请求参数、请求头等。

    StandardJMeterEngine 类:代表 JMeter 引擎,负责配置和执行测试计划。通过将测试计划配置给引擎,可以启动和执行性能测试。

    JMeterUtils 类:提供了一些 JMeter 的实用方法和属性。通过加载 JMeter 属性文件并初始化本地设置,可以确保 JMeter API 的正确运行。

      为了能够在代码中创建和配置测试计划、线程组、循环控制器和其他元素,以及执行性能测试,这些类的功能和方法是我们必须要熟悉的。掌握了这些类,那么利用jmeter如何编写性能测

    试脚本是怎样的,我们也来回顾下:

    JMeter 编写性能测试脚本的大致流程示意图:

    源码实现方式:

    (1) 环境初始化

    需要在项目中引入 上述JMeter核心API,这样我们才能使用 JMeter 提供的各种功能和类

    1. import org.apache.jmeter.control.LoopController;
    2. import org.apache.jmeter.engine.StandardJMeterEngine;
    3. import org.apache.jmeter.protocol.http.sampler.HTTPSampler;
    4. import org.apache.jmeter.testelement.TestPlan;
    5. import org.apache.jmeter.threads.ThreadGroup;
    6. import org.apache.jmeter.util.JMeterUtils;
    (2) 环境初始化

    JMeter API 在执行过程中,首先会读取 JMeter 软件安装目录文件下配置文件里的属性,所以我们要通过 JMeter API 读取指定的 JMeter 主配置文件的目录以及 JMeter 的安装目录,

    其中环境初始化主要包括以下 2 个步骤:

    通过 JMeterUtils.loadJMeterProperties 加载 JMeter 主配置文件 JMeter.properties,然后把 jmeter.properties 中的所有属性赋值给 JMeterUtils 对象,以便之后获取所需的配置;
    设置 JMeter 的安装目录,JMeter API 会根据我们指定的目录加载脚本运行时需要的配置

    1. JMeterUtils.loadJMeterProperties("jmeter.properties");JMeterUtils.setJMeterHome(~/jemter)
    2. JMeterUtils.initLocale();
    (3) 创建测试计划

    使用 TestPlan 类创建一个测试计划,并设置相关属性。

    1. TestPlan testPlan = new TestPlan("My Test Plan");
    2. testPlan.setProperty(TestElement.TEST_CLASS, TestPlan.class.getName());
    3. testPlan.setProperty(TestElement.GUI_CLASS, TestPlanGui.class.getName());
    (4) 创建 ThreadGroup

    使用 ThreadGroup 类创建一个线程组,并设置相关属性,例如线程数、循环次数等

    1. ThreadGroup threadGroup = new ThreadGroup();
    2. threadGroup.setName("My Thread Group");
    3. threadGroup.setNumThreads(10);
    4. threadGroup.setRampUp(5);
    5. threadGroup.setSamplerController(loopController);
    (5) 创建循环控制器

    这一步是一个可选项。我们在实际测试过程中,创建循环控制器是为了模拟一个用户多次进行同样操作的行为,不创建循环控制器则默认是只执行一次操作。循环控制器创建的代码如下:

    1. LoopController loopController = new LoopController();
    2. //设置循环次数,1 代表循环 1
    3. loopController.setLoops(1);
    4. loopController.setFirst(true);
    5. loopController.setProperty(TestElement.TEST_CLASS, LoopController.class.getName());
    6. loopController.setProperty(TestElement.GUI_CLASS, LoopControlPanel.class.getName());
    7. loopController.initialize()
    (6) 创建 Sampler

    使用 HTTPSampler 类创建一个 HTTP 请求采样器,并设置请求的 URL、方法等属性

    1. HTTPSampler httpSampler = new HTTPSampler();
    2. httpSampler.setDomain("example.com");
    3. httpSampler.setPort(80);
    4. httpSampler.setPath("/api/endpoint");
    5. httpSampler.setMethod("GET");
    (7) 创建结果收集器

    结果收集器可以保存每次 Sampler 操作完成之后的结果的相关数据,例如,每次接口请求返回的状态、服务器响应的数据。

    1. ResultCollector resultCollector = new ResultCollector();
    2. resultCollector.setName(ResultCollector.class.getName());
    (8) 构建 tree,生成 jmx 脚本

    以上步骤其实都是为了创建了一个 HashTree 节点做准备。把创建都添加到 子 HashTree 节点中,然后把子 HashTree 加到 testplan 中,最后再把 tesplan 节点加到构建好的父 HashTree 节点,这样就生成了我们的脚本可执行文件 jmx。代HashTree subTree = new HashTree(

    通过以上代码就可以创建出 JMeter 可识别的 HashTree 结构,并且可以通过 saveTree 保存为 test.jmx 文件。如果是现成的jmx文件,可直接通过 HashTree jmxTree =

    SaveService.loadTree(file); loadTree 会把 jmx 文件转成内存对象,并返回内存对象中生成的 HashTree。

    1. subTree.add(httpSamplerProxy);
    2. subTree.add(loopController);
    3. subTree.add(threadGroup);
    4. subTree.add(resultCollector);
    5. HashTree tree = new HashTree();
    6. tree.add(testPlan,subTree);
    7. SaveService.saveTree(tree, new FileOutputStream("test.jmx"));
    8. } catch (IOException e) {
    9. e.printStackTrace();
    10. }
    (9) 测试执行

    通过脚本文件的执行(测试执行),我们便可以开始对服务器发起请求,进行性能测试。测试执行主要包括 2 个步骤:

    1. 把可执行的测试文件加载到 StandardJMeterEngine;
    2. 通过 StandardJMeterEngine 的 run 方法执行,便实现了 Runable 的接口,其中 engine.run 执行的便是线程的 run 方法
    1. StandardJMeterEngine engine = new StandardJMeterEngine();
    2. engine.configure(jmxTree);
    3. engine.run();
    (10) 结果收集

      JMeter API 提供了一个结果收集器(ResultCollector),用于收集和处理性能测试结果。它是 SampleListener 接口的一个实现类,可以监听每个测试样本的事件,并对测试结果进行处理。我们可以重写 sampleOccurred 方法来收集每次 loop 的结果。该方法的参数 SampleEvent 中包含相应的测试结果。然后把测试结果数据存到消息队列里面,比如kafka ,后端获取存

    储的实时采集数据,进行相应的计算,生成的数据返回给前端进行绘制展示。

    最后感谢每一个认真阅读我文章的人,礼尚往来总是要有的,虽然不是什么很值钱的东西,如果你用得到的话可以直接拿走:

    在这里插入图片描述

    这些资料,对于【软件测试】的朋友来说应该是最全面最完整的备战仓库,这个仓库也陪伴上万个测试工程师们走过最艰难的路程,希望也能帮助到你!   

  • 相关阅读:
    大模型算法岗 100 道面试题(含答案)
    磨金石教育摄影技能干货分享|花朵怎样拍才能不凌乱
    全球与中国数字万用表市场:增长趋势、竞争格局与前景展望
    Reactor模型
    测试杂谈——一条SQL引发的思考
    设计模式-代理模式
    C/C++轻量级并发TCP服务器框架Zinx-游戏服务器开发003:架构搭建-需求分析及TCP通信方式的实现
    【MATLAB】立体透视
    前端模块化学习:CommonJS规范、AMD规范、CMD规范、ES6规范
    【关于Linux中----文件接口、描述符、重定向、系统调用和缓冲区】
  • 原文地址:https://blog.csdn.net/2301_78843735/article/details/133274652