首页 > 其他分享 >jmeter.5.4.1

jmeter.5.4.1

时间:2022-12-15 18:38:15浏览次数:60  
标签:脚本 4.1 JSR223 样本 采样器 线程 jmeter.5 JMeter

采样器

JSR223

JSR是Java Specification Requests的缩写,意思是Java规范提案.是指向JCP(Java Community Process)提出新增一个标准化技术规范的正式请求.任何人或组织都可以向JCP提交JSR,以向Java平台增添新的API和服务.JSR已成为Java界的一个重要标准.

JSR223定义了可集成在Java平台上运行的一系列脚本语言.比如Groovy,JavaScript等.

JSR223 采样器允许脚本用于样本执行或一些创建/更新变量必须的计算。

当采样器运行时,如果你不需要生成​​样本结果​​,调用以下方法:

SampleResult.setIgnore();

这个调用会产生以下影响:

  • 样本结果不会传输到样本监听器,比如:查看结果树(View Results Tree)、统计描述(Summariser)等
  • 样本结果也不会在断言(Assertions)和后置处理器(PostProcessors)中评估
  • 样本结果将会用于评估样本最后的的状态(${JMeterThread.last_sample_ok}),并且线程组“采取采样器错误的措施”(自 JMeter 5.4 起)

JSR223 测试元素有一个特性(编译),它可以显著提升性能。要从这个特性中获取好处:

  • 使用脚本文件代替内嵌它们。这将使 JMeter 编译并缓存它们,如果这个特性适用于脚本引擎(ScriptEngine)。
  • 或使用脚本文本并检查​​Cache compiled script if available(缓存编译过的脚本如果可用)​​属性。当使用这个特性时,确保你的脚本代码没有使用 JMeter 变量或者 JMeter 函数调用,因为缓存只会缓存第一次替换。使用脚本参数代替。要从缓存和编译中获得好处,使用的脚本语言引擎必须实现 JSR 223 编译接口(Groovy 是其中之一,beanshell 和 javascript 不是)当使用 Groovy 做为脚本语言并且不检查Cache compiled script if available(推荐使用缓存),你应该设置 JVM 属性 -Dgroovy.use.calssvalue=true 因为 Groovy 2.4.6 版本内存泄漏,查看:

缓存大小通过 JMeter 属性控制(jmeter.properties):

jsr223.compiled_scripts_cache_size=100

不同于 BeanShell 采样器,解释器不在调用间保存。

JSR223 测试元素使用脚本文件或脚本文本并且选中 Cache compiled script if available(缓存编译过的脚本如果可用)并编译,如果脚本引擎支持这个特性,这将极大的提升性能。

jmeter.5.4.1_缓存

在将脚本字段传递给解释器之前,JMeter 会处理函数和变量引用,所以引用只会解释一次。脚本文件中变量和函数引用将一字不差的传到解释器,它很可能导致语法错误。为了使用运行时变量,请使用合适的属性方法,例如:

props.get("START.HMS");

props.put("PROP1","1234");

参数

属性

描述

必填

Name(名称)

采样器在树中的展示描述

No

Scrpiting Language(脚本语言)

使用的 JSR223 脚本语言名称

Yes

 

不止在下拉列表中显示的语言支持。如果合适的 jar 包安装在 JMeter lib 文件夹下,则有可能适用。注意有的语言比如 Velocity 可能对 JSR223 变量使用不同的语法,例如:

$log.debug("Hello " + $vars.get("a"));

 

Script File(脚本文件)

用于 JSR223 脚本的文件名,如果使用相对地址,那么它将通过"user.dir"系统特性关联到文件夹

No

Parameters(参数)

传递到脚本文件或者脚本的参数集合

No

Cache compiled script id available(缓存编译过的脚本如果可用)

如果选中(建议选中)并且语言支持编译接口(Groovy 是其中之一,java、beanshell和 javascript 不是),JMeter 将会编译脚本并使用缓存,脚本的 MD5 哈希值做为存储主键

No

Script(脚本)

传到 JSR223 语言的脚本

Yes(除非提供脚本文件)

如果支持脚本文件,那么优先使用脚本文件,否则使用脚本。

调用脚本前,一些变量会装配。注意有 JSR223 变量 - 例如:它们可以直接用于脚本。

  • log - ​​日志工具​
  • Label - 采样器标签
  • FileName - 文件名,如果有的话
  • Parameters - 从参数字段获取的文本
  • args - 参数,如上所述拆分
  • SampleResult - 指向当前​​样本结果​
  • sampler - (Sampler) - 指向当前采样器
  • ctx - ​​JMeterContext​
  • ctx - ​​JMeterVariables​​​ - 例如:
    vars.get("VAR1");
    vars.put("VAR2","value");
    vars.remove("VAR3");
    vars.putObject("OBJ1",new Object());
  • props - JMeter属性(类 ​​java.util.Properties​​​)
    props.get("START.HMS");
    props.put("PROP1","1234");
  • OUT - System.out - 例如:OUT.println("message")

​样本结果​​​ 响应数据设置来自脚本的返回结果。如果脚本返回 null ,它可以,通过使用方法 ​​SampleResult.setResponseData(data)​​​ 直接设置响应,返回数据类型要么是 String 要么是 byte 数组。返回数据类型默认“text”,但是可以通过方法​​SampleResult.setDataType(SampleResult.BINARY)​​设置二进制。

样本结果变量给予脚本所有字段和方法的访问权。例如,脚本有权限访问方法​​setStopThread(boolean)​​​ 和 ​​setStopTest(boolean)​​。

不同于 BeanShell 采样器, JSR223 采样器不设置 ResponseCode,ReponseMessage 并且样本状态借助于脚本变量。当前修改这些数据唯一的办法是通过样本结果方法:

  • SampleResult.setSuccessful(true/false)
  • SampleResult.setResponseCode("code")
  • SampleResult.setResponseMessage("message")

Best Practices (最佳实践)

设置正确的线程数量

除了硬件性能,测试计划(Test Plan)设计也同样会影响 JMeter 运行有效线程数量。线程数量还将依赖你的服务速度(更快的服务器使 JMeter 工作更快,因为服务器响应更快)。与任何负载测试(Load Testing)工具一样,如果不恰当的设置线程数量,你将面临“协调遗漏(Coordinated Omission)”问题,它会给你错误或不精确的结果。如果你需要大规模负载测试,考虑在多个机器上使用分布式模式(或者不用)运行多个 CLI JMeter 实例。当使用分布式模式时,结果文件在控制器节点(Controller node)中组合,如果使用多个自主实例,样本结果可以组合起来以供后续分析。为了测试 JMeter 如何在给定的平台上执行,可以使用 JavaTest 采样器。它不需要任何网络访问,因此可以对最大可达吞吐量给出一些头绪。

JMeter 有延迟线程创建的选择,直到线程开始采样。例如:在任何线程组延迟和线程自身启动(ramp-up)时间。这将允许对于一个很大的总线程数量,具有不同时激活太多的能力。

jmeter.5.4.1_缓存_02

如何设置正确的线程数量
  • 最大线程数量依赖于
  • 运行 JMeter 的机器的功率
  • JVM 32位还是64位
  • JVM 分配的最大堆大小 -Xmx
  • 测试计划(大量的 beanshell 脚本、前置处理器等意味着消耗更多的 CPU)
  • 操作系统配置
  • GUI/NON-GUI 模式

所以没有一个理论能直接得到最大线程数量。

  • 设置正确的线程数量
  • 多次设置不同线程数量,观察吞吐量,找出合适的线程数量

Aggregate Report(聚合报告)

聚合报告在你的测试中为每个不同命名的请求在表格中创建一行。它为每个请求汇总返回信息并提供请求次数、最短时间(同一个样本,ms)、最长时间(同一个样本,ms)、平均时间(结果集中的平均时间,ms)、错误率(请求错误比例)、近似吞吐率(请求/秒)和每秒 KB 吞吐量。一旦完成测试,吞吐量是整个测试期间的真实吞吐量。

吞吐量是从采样器目标的角度计算的(例如:在 HTTP 样本情况下的远程服务器)。JMeter 把生成请求的时间算入总时间。如果其它采样器和计时器在同一个线程中,他们将会增加总时间,并因此减少吞吐量。所以两个完全相同不同名字的采样器相对两个有相同名字的采样器只有一半的吞吐量。要从聚合报告中获取最佳结果,选择正确的采样器名字很重要。

计算​​中位数​​和 90% Line(​​第90百分位​​)值需要额外的内存。JMeter 现在通过相同的消耗时间联合样本,到目前为止,它使用的内存更少。然而,对于超过几秒钟的样本,可能只有少数样本有相同的时间,这种情况下需要消耗更多的内存。注意,之后您可以使用此侦听器重新加载CSV或XML结果文件,这是避免对性能造成影响的推荐方法。

从 JMeter 2.12 开始,你可以配置 3 个你要计算的百分比值,可以通过设置属性完成:

  • aggregate_rpt_pct1:默认 第 90 区间
  • aggregate_rpt_pct2:默认 第 95 区间
  • aggregate_rpt_pct3:默认 第 99 区间
  • Label - 样本的标签。如果选中 "Include group name in label?",那么线程组的名称会做为前缀加到标签中。这样,可以根据需要分别整理来自不同线程组的相同标签。

Samples - 具有相同标签的的样本数量

  • Average - 一个结果集中的平均时间
  • Median - 中位数是结果集中的中间数。 50% 的样本花费不超过这个时间;剩余的至少花费了一样的时间。
  • 90% Line - 百分之 90 的样本花费不超过这个时间。剩余的样本至少花费了一样的时间。(第 90 百分位)
  • 95% Line - 百分之 95 的样本花费不超过这个时间。剩余的样本至少花费了一样的时间。(第 95 百分位)
  • 99% Line - 百分之 99 的样本花费不超过这个时间。剩余的样本至少花费了一样的时间。(第 99 百分位)
  • Min - 同一个标签里样本的最短时间
  • Max - 同一个标签里样本的最长时间
  • Error % - 错误请求百分比
  • Throughput - 吞吐量用与测量每秒钟/分钟/小时的请求数。时间单位是选择的所以显示比例至少是 1.0。当吞吐量保存到 CSV 文件时,它通过 请求数/秒 表示,例如:30.0 请求数/分 保存为 0.5 请求数/秒。
  • Recieved KB/sec - 吞吐量测量每秒接收到的 KB 数
  • Sent KB/sec - 吞吐量测量每秒发送的 KB 数

时间以毫秒为单位。

Label

# Samples

Average

Median

90% Line

95% Line

99% Line

Min

Max

Error %

Throughput

Received KB/sec

Sent KB/sec

Http Request - 1

200

303

259

489

673

986

147

1069

0.000%

0.09529

0.02

0.02

Http Request - 2

100

229

222

288

319

358

143

381

0.000%

81.63265

18.46

18.73

Http Request - 3

100

225

194

324

440

506

146

677

0.000%

85.91065

20.42

19.72

TOTAL

400

265

226

392

496

882

143

1069

0.000%

0.17941

0.04

0.04

术语表

中位数 是一个把样本分为两等份的数字。一半样本小于中位数,另一半比中位数大。【有的样本可能等于中位数。】这是一个标准的统计学测量。中位数和第 50 百分位是相同的。

90% Line 第 90 百分位是低于 90% 样本的值。剩余的样本至少和这个值一样长。这个一个标准的统计学测量

学而不思则罔,思而不学则殆



标签:脚本,4.1,JSR223,样本,采样器,线程,jmeter.5,JMeter
From: https://blog.51cto.com/u_15766933/5945618

相关文章

  • NLP:14.1 词嵌入(Word2vec)李沐
    李沐动手学深度学习学习笔记 词向量是⽤于表⽰单词意义的向量,并且还可以被认为是单词的特征向量或表⽰。将单词映射到实向量的技术称为词嵌⼊。近年来,词嵌⼊逐渐成......
  • win7 64 + Ubuntu 14.04.1 64双系统安装,详解UEFI ~ GPT和legacy ~ MBR区别
    win764+Ubuntu14.04.164双系统安装背景:我的笔记本之前的系统是window764+Ubuntu14.04.1,用UEFI引导系统。安装过程是先装的win7,再装Ubuntu。本来挺和谐的搭配,但是......
  • Premiere Pro 2021for Mac中文版(pr 2021直装版)v15.4.1
    PremierePro2021forMac是一款功能强大的视频编辑软件,pr2022中文版具有智能化视频剪辑工具,可以为您提供采集、剪辑、调色、美化音频、字幕添加、输出、DVD刻录的一整套流......
  • 4.1IDA基础设置--《恶意代码分析实战》
    1.加载一个可执行文件①选项一:当加载一个文件(如PE文件),IDA像操作系统加载器一样将文件映射到内存中。②选项三:BinaryFile:将文件作为一个原始的二进制文件进行反汇编,......
  • spring security 4.1两个不错功能介绍
    一转眼,springsecurity已经发布4.1了,查看了下新特性,有两个比较值得关注:1)可以在pathvariable形式的URL中进行保护了 比如有个方法:[code=......
  • Day34.1:Date
    Date1.1Date概述Date表示特定的瞬间时间,精确到毫秒。Date中大部分的方法都被Calendar类的方法所取代。时间单位:1秒=1000毫秒1毫秒=1000微秒1微秒=1000纳秒1.2Date......
  • NVIDIA Jetson TX2安装opencv4.1
    mkdirbuildvimcv_cmake.sh#!/bin/bashcmake\-DCMAKE_BUILD_TYPE=Release\-DCMAKE_INSTALL_PREFIX=/usr\-DBUILD_PNG=OFF\......
  • 4.1 数列的概念2 (递推公式、前n项和)
    \({\color{Red}{欢迎到学科网下载资料学习}}\)[【基础过关系列】高二数学同步精品讲义与分层练习(人教A版2019)](https://www.zxxk.com/docpack/2875423.html)\({\col......
  • 4.1 数列的概念1(概念、通项公式)
    \({\color{Red}{欢迎到学科网下载资料学习}}\)[【基础过关系列】高二数学同步精品讲义与分层练习(人教A版2019)](https://www.zxxk.com/docpack/2875423.html)\({\col......
  • MyCms 自媒体系统 v4.1 发布,对接公众号文章排版发布
    MyCms是一款基于Laravel开发的开源免费的开源多语言商城CMS企业建站系统。MyCms基于Apache2.0开源协议发布,免费且可商业使用,欢迎持续关注我们。V4.1更新内容......