Jmeter 用户手册
名词解释:
RPS:每秒请求数-每秒向服务器发送多少请求数(一个场景,系统面临多大的压力)
TPS:每秒事务数-每秒能够处理多少请求/事务数性能评价标准(其中的一个核心指标,吞吐量)
RT:响应时间,指的是业务从客户端发起到客户端接收时间
线程组:线程-虚拟用户(VU),不同场景不同线程组
循环:控制线程任务执行的次数
任务:线程组内部的逻辑步骤
压测场景
-
具体场景:比如压测目标:确认系统能否达到 20 TPS,持续压测 10 s
前提:模拟出 RPS 达到 20 RPS -
第一种错误方案:线程数:1 ,Ramp-UP:1,循环:20?
1、压测时间-太短,不准确
2、一个线程循环 20 次,并不是模拟 20 RPS
1个线程1秒可能发起几百次请求,任务执行的速度很快–8 ms–1000ms/8=125 RPS -
第二种错误方案:线程数:20 ,Ramp-UP:1,循环:永远,持续时间 10s?
1、RPS 远远超出预料范围(1600 RPS),服务器是否能承受这么大的压力?
2、模拟压测场景脱离实际,如果服务器宕机,则压测结果没有任何参考意义!
如何调整?- 第一种调整方案:调整线程数量,比如将线程数调整为 1 ,但这种方案仍旧达不到目标
- 第二种调整方案:调整任务执行的频率:比如:加定时器-常数吞吐量定时器,每分钟样本量 60个,基于
只有此线程
,这样设置后,每秒执行一次线程任务,即 20 个请求
-
第三种错误方案:线程数:20 ,Ramp-UP:1,循环:永远,持续时间 10s,常数吞吐量定时器(每分钟样本量 60 个)–【巨大 BUG】
-
因为并发量越大,响应时间越慢,可能超过 1 秒,导致压测结果不准确
-
场景细化:20 个线程工作(响应时间需要 3 s)
- 第一秒:20 个线程发送 http 请求—RPS:20
- 第二秒:0 个线程发送 http 请求—RPS:0
- 第三秒:0 个线程发送 http 请求—RPS:0
- 第四秒:20 个线程发送 http 请求—RPS:20
-
最后正确调整方案:每分钟样本量 1200 个,基于
所有活动线程
-
场景细化:20 个线程工作(响应时间需要 3 s)
- 第一秒:0-20 编号线程发送 http 请求—RPS:20
- 第二秒:20-40 编号线程发送 http 请求—RPS:20
- 第三秒:40-60 编号线程发送 http 请求—RPS:20
- 第四秒:0-20 编号线程发送 http 请求—RPS:20
-