性能测试学习之路(九)—Jmeter之定时器详解

JMeter中的定时器一般被我们用来设置延迟与同步。定时器的执行优先级高于Sampler(取样器),在同一作用域(比如控制器下)下有多个定时器存在时,每一个定时器都会执行:如果想让某一定时器仅对某一Sampler有效,则可以把定时器加在此Sampler 节点下。

我们一般常用的定时器也就是固定定时器和同步定时器。这期我们主要将这两个,其余定时器不常用大家想要理解的可以百度一下。

固定定时器

顾名思义就是固定延迟时间,如图设置每个线程延迟为1000毫秒也就是1s,这样我们运行时,每个线程之间时间都是差1s。我们可以用监听器中的以表格查看结果来看时间。如下图所示:

可以看到基本每个线程间几乎都是间隔1000ms(1s)左右。

同步定时器

用来模拟多用户并发,或者说更严格的并发场景。同步定时器讲究的是"同步"也就是同一时刻。它是用来设置集合点,阻塞线程,同步虚拟用户,直到指定的线程数量到达后,恰好在同一时刻执行任务,再一起释放,可以瞬间对服务器产生很大的压力。

注意:一般情况,并发用户数多少,同步定时器就写多少。(多少并发就要等多少个人到齐一起释放)

模拟用户组数量 :集合点个数 (执行的线程数),如果设置为0,等于设置为线程租中的线程数量。
超时时间 :指定线程数多少秒没集合到算超时(以毫秒为单位),默认为0。

如果设置为0,该定时器将会等待线程数达到了 "模拟用户组数量" 中设置的值才释放,不够的话就死等。

如果大于0,那么如果超过 "超时时间" 中设置的最大等待时间后还没达到 "模拟用户组数量" 中设置的值,Timer 将不再等待,释放已到达的线程。

如上图同步定时器设置的为当模拟用户数到达10再执行请求,当时间超过了3000ms,到达几个模拟用户就释放几个。可以用表格查看结果来发现这10个请求的Start time是一样的(可能会差个几毫秒)。

相关推荐
半夏知半秋2 小时前
docker常用指令整理
运维·笔记·后端·学习·docker·容器
蒸蒸yyyyzwd2 小时前
网络编程——threadpool.h学习笔记
笔记·学习
浪子不回头4152 小时前
SGLang学习笔记
人工智能·笔记·学习
deng-c-f3 小时前
Linux C/C++ 学习日记(53):原子操作(二):实现shared_ptr
开发语言·c++·学习
码luffyliu4 小时前
系统优化:从压测到性能飞升
后端·压力测试
旖旎夜光4 小时前
Linux(3)(下)
linux·学习
geneculture4 小时前
从智力仿真到认知协同:人机之间的价值对齐与共生框架
大数据·人工智能·学习·融智学的重要应用·信智序位
sbc-study5 小时前
comsol仿真例题学习-模块-水平集+相场法
学习·comsol·例题·水平集·相场法·电镀
EchoL、5 小时前
Obsidian使用学习
笔记·学习