1、定时器是在每个sampler(采样器)之前执行的,而不是之后(无论定时器位置在sampler之前还是下面);

2、当执行一个sampler之前时,所有当前作用域内的定时器都会被执行;

3、如果希望定时器仅应用于其中一个sampler,则把定时器作为子节点加入;

4)如果希望在sampler执行完之后再等待,则可使用Test Action;

 

一、固定定时器,让作用域内的请求延迟固定的时间启动固定定时器的延时不会计入单个sampler的响应时间

JMeter元件(二)-常用定时器_JMeter学习

 

 

二、高斯随机定时器(Gaussian Random Timer)

JMeter元件(二)-常用定时器_JMeter学习_02

如需要每个线程在请求前按随机时间停顿,那么使用这个定时器,上图表示暂停时间会分布在100到400之间,计算公式参考:Math.abs((this.random.nextGaussian() * 3000) + 1000)

 

执行如下脚本,查看时间的偏移值

JMeter元件(二)-常用定时器_JMeter教程_03

 

执行时间如图

JMeter元件(二)-常用定时器_JMeter学习_04

 

 

三、统一随机定时器,与高斯随机定时器的作用差异不大,区别在于延时时间在指定范围内且每个时间的取值概率相同,每个时间间隔都有相同的概率发生,总的延迟时间就是随机值和偏移值之和。

(1)Random Delay Maximum(in milliseconds):随机延迟时间的最大毫秒数

(2)Constant Delay Offset(in milliseconds):暂停的毫秒数减去随机延迟的毫秒数

JMeter元件(二)-常用定时器_JMeter学习_05

 

四、同步定时器(Synchronizing Timer)

这个定时器和loadrunner当中的集合点(rendezvous point)作用相似,其作用是:阻塞线程,直到指定的线程数量到达后,再一起释放,可以瞬间产生很大的压力

(1)Number of Simulated Users to Group by:模拟用户的数量,即指定同时释放的线程数数量

(2)Timeout in milliseconds:超时时间,即超时多少毫秒后同时释放指定的线程数

 

JMeter元件(二)-常用定时器_JMeter教程_06

 

五、固定吞吐量定时器(Constant Throughput Timer)

JMeter元件(二)-常用定时器_JMeter教程_07

 

固定吞吐量定时器可以让jmeter以指定数字的吞吐量(即指定TPS,只是这里要求指定每分钟的执行数,而不是每秒)执行,如图为设置的每秒20qps的吞吐量

 

3、Delay before each affected samler

1)Target throughput(in samples per minute):每分钟的天吐量

2) Calculate Throughput based on:有5个选项:

第一: This thread only:控制每个线程的吞吐量,选择这种模式时,总的吞吐量为设置的target Throughput 乘以该线程的数量

第二: All active threads:设置的target Throughput 将分配在每个活跃线程上,每个活跃线程在上一次运行结束后等待合理的时间后再次运行。活跃线程指同一时刻同时运行的线程。

第三:All avtive threads(shared):与All active threads的选项基本相同。唯一区别是,每个活跃线程都会在所有活跃线程上一次运行结束后等待合理的时间后再次运行。

第四: All active threads in current thread group:设置的target Throughput 将分配在当前线程组的每一个活跃线程上,当测试计划中只有一个线程组时,该选项和All active threads 选项的效果完全相同。

第五:All active threads in current thread group(shared):与All active threads in current thread group 基本相同,唯一的区别是,每个活跃线程都会在所有活跃线程的上一次运行结束后等待合理的时间后再次运行。