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
相关推荐
程序员的世界你不懂12 小时前
Jmeter的元件使用介绍:(三)配置元件详解01
jmeter
软件测试-阿涛17 小时前
【性能测试】Jmeter+Grafana+InfluxDB+Prometheus Windows安装部署教程
测试工具·jmeter·性能优化·压力测试·grafana·prometheus
YuforiaCode2 天前
JMeter每次压测前清除全部以确保异常率准确(以黑马点评为例、详细图解)
jmeter
程序员的世界你不懂2 天前
Jmeter的元件使用介绍:(四)前置处理器详解
开发语言·python·jmeter
清心歌2 天前
Apache JMeter 使用记录踩坑
jmeter·apache
程序员的世界你不懂2 天前
Jmeter的函数助手使用
jmeter
程序员的世界你不懂2 天前
Jmeter常见问题分析(1)乱码问题
jmeter·dubbo
黑哒哒的盟友2 天前
JMeter groovy 编译成.jar 文件
java·jmeter·jar
程序员的世界你不懂2 天前
Jmeter的元件使用介绍:(二)线程组详解
jmeter