场景:
Jmeter线程启动了就会直接发送测试请求;
如果要模拟在一瞬间高并发量测试的时候,需要调高线程数量,这很耗测试机器的性能,往往无法支持较大的并发数,无法控制每次测试的瞬间并发量。
那么,该如何解决上述问题呢?
解决方案:
使用集合点。阻塞线程,直到指定的线程数量到达后,再一起释放,可以瞬间产生很大的压力。
操作步骤:
1、添加集合点,在Jmeter里是synchronized timer;
1)、Number of Simulated Users to Group by
a.每集合够多少个模拟用户(线程)后发送一次测试请求;
b.如果设置为0,等同于设置为线程租中的线程数;
c.确保设置的值不大于它所在线程组包含的用户数(线程数)-- 一直集结线程而不发出测试请求,直到超时(如果设置了的话)。
例子说明:“Number of Simulated Users to Group by: 5”表示并发量是5。也就是说,Jmeter会等到5个线程都运行到此处时,这五个线程才开始执行后面的操作,先到达的线程将会在此等候。
2)、Timeout in milliseconds
a.超时时间,即多少毫秒后同时释放已集结的的线程,发送测试请求;
b.如果设置为0,Timer将等待线程数达到了"Number of Simultaneous Users to Group"中设置的值才释放。如果大于0,那么如果超过Timeout in milliseconds中设置的最大等待时间(毫秒为单位)后还没达到"Number of Simultaneous Users to Group"中设置的值,Timer将不再等待,释放已到达的线程。
3)、这里设置:
Number of Simulated Users to Group by :10
Timeout in milliseconds :500
2、设置线程组属性
因为现在是使用集合点来实现高并发测试,所以现在线程组属性中就可以设置线程在较长的时间来启动,这样测试机器的压力就会相对小一点;
3、添加相关请求,结果树等,运行查看效果
通过结果树可以看到,请求是批量执行的;
1)开始执行的脚本,观察请求的增加数量趋势;
2)对比请求的发送时间;