例如:现要加载100个线程,希望聚合报告中分别展示:1-20,20-40,40-60,60-80的四个阶段的线程并发性能数据,而不是一并总体的统计数据。
实现方法:Jmeter通过自定义代码去实现
①添加阶梯线程组
测试计划->添加->Threads->jp@gc-Stepping Thread Group (deprecated)
一共5个阶梯,每次加载20个,最终希望加载100个线程
②添加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");}
③添加事物控制器和请求
把opms的login请求放到事物控制器下,事物控制器的名称是获取的Thread变量,中间也可以添加一些监听器。
④执行压测脚本,查看聚合报告
感谢每一个认真阅读我文章的人,礼尚往来总是要有的,虽然不是什么很值钱的东西,如果你用得到的话可以直接拿走:
这些资料,对于【软件测试】的朋友来说应该是最全面最完整的备战仓库,这个仓库也陪伴上万个测试工程师们走过最艰难的路程,希望也能帮助到你!有需要的小伙伴可以点击下方小卡片领取