jmeter阶梯式性能指标监听
01
概述
我们在进行阶梯式压力测试的时候,聚合报告生成的结果是一个汇总数据。并不会阶梯式的统计压测性能数据。这样我们就不能去对比不同阶梯压力下的性能数据变化趋势。
02
期望
假设现在一共会加载100个线程,我期望聚合报告中分别展示1-20,20-40,40-60,60-80的四个阶段的线程并发性能数据,而不是一共总体的统计数据。
03
实现
jmeter本身不具备这样的工具,需要通过自定义代码去实现。
1添加阶梯线程组
测试计划》添加》Threads》jp@gc - Stepping Thread Group (deprecated)
共5个阶梯,每次加载20个,最终希望加载100个线程
2添加BeahShell脚本
代码实现了实时获取活动的线程总数,根据活动线程总数赋值给变量Thread供后续事务调用
import org.apache.jmeter.threads.JMeterContextService;
int num = JMeterContextService.getNumberOfThreads();
System.out.println("当前活动线程数=" +num);
if(num<=20){
System.out.println("线程区间1-20");
vars.put("Thread","线程数1-20");
}
else if (num>20&&num<=40){
System.out.println("线程区间20-40");
vars.put("Thread","线程数20-40");
}
else if(num>40&&num<=60){
System.out.println("线程区间40-60");
vars.put("Thread","线程数40-60");
}
else {
System.out.println("线程区间60-100");
vars.put("Thread","线程数60-100");
}
3添加事物控制器和请求
把opms的login请求放到事物控制器下面。事物控制器的名称是获取的Thread变量。中间也可以添加一些监听器
2执行压测脚本,观察聚合报告
04
演示小视频
转载:微信公众号搜索 测试驿栈
号内回复 mock,会下发mock接口让各位练习
基础入门
接口自动化关联
必知必会的操作
jmeter高级操作系列
java_selenium自动化(最新更新)
接口自动化实战系列
循环控制器+交替控制器+事务控制器 完美实现接口字段参数化校验
Docker+Jmeter+Gitlab+Jenkins+Ant(容器化的接口自动化持续集成平台)
性能测试系列
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· 没有Manus邀请码?试试免邀请码的MGX或者开源的OpenManus吧
· 【自荐】一款简洁、开源的在线白板工具 Drawnix
· 园子的第一款AI主题卫衣上架——"HELLO! HOW CAN I ASSIST YOU TODAY
· Docker 太简单,K8s 太复杂?w7panel 让容器管理更轻松!