JMeter 性能测试

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
相关推荐
hgz07102 小时前
Linux服务器环境部署与JMeter压测准备
linux·服务器·jmeter
早川91911 小时前
JMeter的基本使用与性能测试
jmeter
hgz07102 天前
JMeter性能压测执行与Linux环境部署
java·linux·jmeter
2501_924064113 天前
JMeter与专业压测平台:效率成本对比及主流平台推荐
jmeter
小毛驴8503 天前
jmeter demo
jmeter
小蝙蝠侠4 天前
12 个“大 TPS 规模效应问题”——现象 + 排查 + 常见解决
jmeter·性能优化
安然无虞6 天前
性能测试·基础理论和指标
测试工具·jmeter·压力测试
安然无虞6 天前
性能测试·流程
测试工具·jmeter·压力测试
write19947 天前
01 jmeter插件以及安装
jmeter
玖釉-8 天前
JMeter 测试计划(Test Plan)与脚本结构详解
jmeter