记录下业务中常用的定时器概念以及使用流程,仅供自己学习。
定时器的作用域
1、定时器是在每个sampler(采样器)之前执行的,而不是之后(无论定时器位置在sampler之前还是下面);
2、当执行一个sampler之前时,所有当前作用域内的定时器都会被执行;
3、如果希望定时器仅应用于其中一个sampler,在sampler下级子节点插入,只会对上级是取样器作用;
4、如果希望在sampler执行完之后再等待,则可以使用Test Action;
该定时器只会对上级接口作用
该定时器会对该线程所有的接口作用
1.Synchronizing Timer-同步定时器
一般用于业务流程事务内的并发测试。例如并发测试某个接口,整个线程是通过多个接口才并发被测接口,如不用定时器,保证不了多线程请求时,是同一时刻测试被测接口,所以需要用该定时器,作用是等待线程数的集合再请求该接口。
5是指等待5个线程才进行下一步
timeout in milllisecond:毫秒单位,指等待超过超时的时间,就会执行
对于超时的概念:
1、实际运行过程中,可能出现始终无法达到集合点设置的并发要求;如果出现这种情况的话Jmeter会一直卡顿在那里,等待满足要求,才会继续往下执行;
2、为了避免上述情况的发生,我们需要设置一下集合点的超时时间
设置规则为:因为集合点超时时间的单位为ms
计算公式:超时时间 > 请求集合数量 * 1000 / (线程数 / 线程加载时间)
2.Constant Throughput Timer-常数吞吐量定时器
可以让JMeter以指定数字的吞吐量(即指定TPS,只是这里要求指定每分钟的执行数,而不是每秒)执行。
例如:让一个接口持续以TPS10执行,即设置 10X60 = 600 ,用此定时器通常会搭配线程组循环进行,以此来监控服务器的性能。
吞吐量计算的范围可以为指定为当前线程、当前线程组、所有线程组等范围,并且计算吞吐量的依据可以是最近一次线程的执行时延。这种定时器在特定的场景下,还是很有用的。
3.固定定时器-Constant Timer
如果你需要让每个线程在请求之前按相同的指定时间停顿,那么可以使用这个定时器;需要注意的是,固定定时器的延时不会计入单个sampler的响应时间,但会计入事务控制器的时间。
对于“事务控制器”来说相当于是接口请求的间隔时间(思考时间:实际操作中,模拟真实用户在操作过程中的等待时间)。
我们通常说的响应时间,应该大部分情况下是针对某一个具体的sampler(http请求),而不是针对一组sampler组合的事务 。