参数说明:

a) 引用名称:下一个请求要引用的参数名称,如填写token,则可用${token}引用它。

b) 正则表达式:

    ():括起来的部分就是要提取的

    .:匹配任何字符串

    +:一次或多次

    ?:在找到第一个匹配项后停止

c) 模板:用$$引用起来,如果在正则表达式中有多个正则表达式,则可以是$2$$3$等等,表示解析到的第几个值给token。如:$1$表示解析到的第1个值

d) 匹配数字:0代表随机取值,1代表全部取值,通常情况下填0

缺省值:如果参数没有取得到值,那默认给一个值让它取。

四、插件管理

Jmeter插件管理plugins-manager.jar 它管理插件包括 http://jmeter-plugins.org 上面常用的插件和各种第三方插件甚至核心JMeter插件

下载地址:https://jmeter-plugins.org/downloads/all/

安装:下载后文件为plugins-manager.jar格式,将其放入jmeter安装目录下的lib/ext目录,然后重启jmeter

jmeter插件

【Jmeter】 性能监控(插件)

1、3 Basic Graphs ---基本图表

包含:

⑴ jp@gc - Transactions per Second

每秒处理事物数即TPS(x轴是测试执行持续时间,y轴是当前时刻事务数)

⑵ jp@gc - Response Times Over Time

事务响应时间(响应时间过程图,x轴是测试执行持续时间,y轴是事务响应时间)

⑶ jp@gc - Active Threads Over Time

随时间变化的活动线程

2、5 Additional Graphs ---附加图表

包含:

⑴ jp@gc - Bytes Throughput Over Time

不同时间吞吐量展示(字节Bytes)

聚合报告里,Throughput是按请求个数来展示的,比如说1.9/sec,就是每秒发送1.9个请求;而这里的展示是按字节

Bytes来展示的图表,表示每秒发送多少字节

⑵jp@gc - Connect Times Over Time

随着时间推移的连接时间

⑶ jp@gc - Hits per Second

每秒点击量

每秒web服务器接收到的请求数

⑷ jp@gc - Response Codes per Second

测试期间返回的每秒响应代码

⑸ jp@gc - Response Latencies Over Time

记录客户端发送请求完成后,服务器端返回请求之前这段时间

3、 PerfMon(Servers Performance Monitoring )---服务器性能监控

(安装后在Jmeter-监听器中显示为"jp@gc - PerfMon Metrics Collector";可添加CPU、Memory、TCP、Disks I/O、network I/O)

(注意:jmeter只能监控tomcat的主机;需要在服务器上启动StartAgent,即把插件解压到服务器上,运行StartAgent。)

4、 Custom Threads Groups --- 自定义线程组

包含:

(1).jp@gc - Stepping Thread Group(在Threads(users)) -步进线程组(以下类似LR中的场景设置)逐步加压

a)This group will star 100 threads -本次设置线程组启动的线程总数为 *个

b) First,wait for N seconds -启动第一个线程之前,需要等待N秒。设置为0s说明不等待,直接启线程

c) Then start N thread -设置最开始时启动 N个线程。可以默认为0

d) Next,add 10 threads every 30 seconds,using ramp-up 5 seconds -每隔30秒,启动10个线程,10个线程在5秒内启动完成

e)Then hold load for 30 seconds -启动的线程总数达到最大值之后,再持续运行30秒

f) Finally,stop 10 threads every 1 seconds -最后停止线程,每1秒停止10个线程;

(2).jp@gc - Ultimate Thread Group(在Threads(users)) -终极线程组

该插件跟Stepping Thread Group线程组有些类似,不过这个是多个线程组设置的结合。执行的时候,每个线程组是同时按照自己的规则开始执行的,每一时刻,得到的结果都是两个线程组的叠加

a) Start Threads Count:当前行启动的线程总数

b) Initial Delay/sec:延时启动当前行的线程,单位秒

c) Startup Time/sec:启动当前行所有线程达峰值所需时间,单位秒

d) Hold Load For/sec:当前行线程达到峰值后的稳定加载时间,单位秒

e) Shutdown Time:停止当前行所有线程所需时间,单位秒

(3).bzm - Arrivals Thread Group(在Threads(users)) -到达线程组

a)Target Rate(arrivals/sec):每分钟到达的数量

b) Ramp Up Time:加速时间

c) Ramp-Up Steps Count:加速步骤计数

d) Hold Target Rate Time:保持目标速率时间

e) Time Unit:时间单位(分钟或者秒)

f) Thread Iterations Limit:线程迭代次数限制(循环次数)

g)Log Threads Status into File:将线程状态记录到文件中(将线程启动和线程停止事件保存为日志文件)

h) Concurrency Limit:虚拟用户的最大数量

(4). bzm - Concurrency Thread Group(在Threads(users)) -并发线程组

a)Target Concurrency:目标并发(线程数)

b) Ramp Up Time:加速时间

c) Ramp-Up Steps Count:加速步骤计数

d)Hold Target Rate Time:保持目标速率时间

e) Time Unit:时间单位(分钟或者秒)

f) Thread Iterations Limit:线程迭代次数限制(循环次数)

g) Log Threads Status into File:将线程状态记录到文件中(将 线程启动和线程停止事件保存为日志文件)

场景举例:

100个线程、3分钟的加速时间、5个加速步骤、持有目标速率6分钟;

解释场景举例:

3分钟除以5步,每步0.6分钟;100个用户除以5步,每步20个用户;每0.6分钟将添加20个用户,直到达到100个用户;达到100个线程后,所有这些线程将继续运行,并一起打到服务器6分钟;

(5). bzm - Free-Form Arrivals Thread Group

(在Threads(users)) -自由形式到达线程组与 Arrivals Thread Group.相同,它只是提供了自由格式的时间表功能)

5、监控内存及CPU等(jconsole)

方法:比较好的监控内存CPU等的小工具

如果已配置Jmeter则不需要配置其他即可打开此小工具;开始——>运行——>输入cmd——> 进入命令界面直接输入:jconsole ——>回车,即可弹出java监视和管理控制台

选择本地进程,并点击一下sun.tools.jconsole.JConsole,就可以查看本地内存、CPU的使用情况(如果该项不能连接,则选择"ApachJMeter.jar",多链接几次可连接成功)

选择远程进程,需要输入被测服务器的IP、端口->输入用户名、密码点击连接即可查看服务器内存、CPU等使用情况

6、生成html测试报告

jmeter -n -t <test JMX file> -l <test log file> -e -o <Path to output folder>

命令参数解析:

-n :以非GUI形式运行Jmeter

-t :source.jmx 脚本路径

-l :运行结果保存路径,此文件必须不存在

-e :在脚本运行结束后生成html报告

-o :用于存放html报告的目录

例如:D:BaiduNetdiskDownloadapache-jmeter-4.0bin

Jmeter -n -t D:Jmeter-script招聘登录+查询.jmx -l D:JmeterTestresportresult.csv -e -0 D:JmeterTestresporthtml

五、Jmeter之参数化

1. 前置处理器-用户参数

1. 配置元件-CSV数据文件设置

文件名:保存信息的文件目录,可以相对或者绝对路径

文件编码:默认为ANSI

变量名称:给csv文件中各列起个名字(有多列时,用英文逗号隔开列名)便于后面引用

分隔符:与csv文件的分隔符保持一致。如文件中使用的是逗号分隔,则填写逗号;如使用的是TAB,则填写t

遇到文件结束符再次循环:到了文件尾是否循环,True—继续从文件第一行开始读取,False—不再循环

晕倒文件结束符停止线程:到了文件尾是否停止线程,True—停止,False—不停止,注:当Recycle on EOF设置为True时,此项设置无效

1随机参数化,选项-函数助手 —Random

六、Jmeter之检查点

要测试的响应字段: 响应文本、Document(text)、URL样本、响应信息、Response Headers、Lgnore Staus 等选项。虽然接口返回的是HTML页面,但对于JMeter来说返回数据为文本,所以,这里可以勾选“响应文本”。

模式匹配规则: 包括、 匹配、 Equals、 Substring。这里只需要验证返回数据中是否包含主要的关键字,所 以, 这里勾选“包括” 。

要测试的模式: 断言的数据。 点击“添加” 按钮, 输入要断言的数据

七、Jmeter之集合点

简单来理解一下,虽然我们的“性能测试”理解为“多用户并发测试”,但真正的并发是不存在的,为了更真实的实现并发的操作,我们可以在需要压力的地方设置集合点

Number of Simulated Users to Group by: 每次释放的线程数量。如果设置为0,等同于线程组中设置的线程数量。

Timeout in milliseconds: 如果设置为0,Timer将会等待线程数达到了”Number of Simultaneous Users to Group”中设置的值才释放。如果大于0,那么超过Timeout in milliseconds中设置的最大等待时间(毫秒为单位)后还没达到”Number of Simultaneous Users to Group”中设置的值,Timer将不再等待,释放已到达的线程。

注意:

Synchronizing timer 仅作用于同一个JVM中的线程,所以,如果使用并发测试,确保”Number of Simultaneous Users to Group by”中设置的值不大于它所在线程组包含的用户数

如果设置Timeout in milliseconds为0且线程数量无法达到"Number of Simultaneous Users toGroup by"中设置的值,那么Test将无限等待,除非手动终止

Synchronizing Timer是在每个sampler(采样器)之前执行的,而不是之后,不管这个定时器的位置放在sampler之后,还是之前

作用域:当执行一个sampler之前时,和sampler处于相同作用域的定时器都会被执行

八、Jmeter之关联

关联是一种动态行为,用以后续的请求(比如HTTP请求)从之前的请求(比如JDBC Request)的响应数据(服务器返回的数据)中直接使用指定的数据

比如:

(1)、用户登录后,session信息都不同,有些操作要使用session,就需要将这个动态的信息保存下来。

(2)、第二个请求提交的参数要从第一个请求的返回数据中获取(用户登录token)

Jmeter中,关联是通过之前请求的后置处理器实现的,具体有XPath Extractor和正则表达式提取器两种方式:

如果需要提取的文本是页面上某个元素的属性值,建议使用XPath;

如果需要提取的文本在页面上的位置不固定,或者不是元素的属性值,建议使用正则

对于大部分请求返回的结果,都是json格式,还可以使用JSON Extractor插件提取数据

常用场景:

1. HTTP请求-》HTTP请求

参数说明:

a) 引用名称:下一个请求要引用的参数名称,如填写token,则可用${token}引用它。

b)正则表达式:

    ():括起来的部分就是要提取的

    .:匹配任何字符串

    +:一次或多次

    ?:在找到第一个匹配项后停止

c) 模板:用$$引用起来,如果在正则表达式中有多个正则表达式,则可以是$2$$3$等等,表示解析到的第几个值给token。如:$1$表示解析到的第1个值

d) 匹配数字:0代表随机取值,1代表全部取值,通常情况下填0

缺省值:如果参数没有取得到值,那默认给一个值让它取。

Variable names : 下一个请求要引用的参数名称 JSONPath Expression:JSON表达式 Match Numbers:匹配哪个,可为空即默认第一个 Default Value:未取到值的时候默认值

1.JDBC Request -》HTTP请求

1) 下载mysql jar包

2) 为Jmeter添加jar文件

下载后解压.zip文件,把mysql-connector-java-x.x.x-bin.jar放到Jmeter安装目录下的lib目录下

或者在测试计划中添加驱动包

1) 启动Jmeter

添加JDBC Connection Configuration

重要参数说明:

a) Variable Name:数据库连接池的名称

b) Database URL:数据库url,jdbc:mysql://主机ip或者机器名称:mysql监听的端口号/数据库名称, 如招聘数据库:jdbc:mysql://172.16.164.175:3300/db_feo_zhaopin_20180702

c) JDBC Driver class:数据库驱动

d) username:数据库登陆的用户名

e) passwrod:数据库登陆的密码

不同数据库具体的填写方式,可以参考下面的表格:

1) 设置好JDBC连接配置后,添加JDBC请求

a) Variable Name Bound to Pool 数据库连接池的名字,需要与JDBC Connection Configuration的Variable Name Bound Pool名字保持一致

b) Query:填写的sql语句未尾不要加“;”

c) Parameter valus:数据的参数值

d) Parameter types:数据的参数类型,可参考:Javadoc for java.sql.Types

e) Variable names:保存sql语句返回结果的变量名

f) Result variable name:创建一个对象变量,保存所有返回的结果

a) Query timeout:查询超时时间

b) Handle result set:定义如何处理由callable statements语句返回的结果

注意:SQL语句输入有中文时,可能查不到数据,需要指定字符的编码、解码格式

jdbc:mysql://172.16.164.175:3300/db_feo_zhaopin_20180702?useUnicode=true&characterEncoding=utf8

作用:

a) 存数据时:

数据库在存放项目数据的时候会先用UTF-8格式将数据解码成字节码,然后再将解码后的字节码重新使用GBK编码存放到数据库中。

b)取数据时:

在从数据库中取数据的时候,数据库会先将数据库中的数据按GBK格式解码成字节码,然后再将解码后的字节码重新按UTF-8格式编码数据,最后再将数据返回给客户端。

1) 将JDBC Request查询结果作为下一个接口参数

注意:当使用jdbc request的结果作为参数时,需要写成${email_1},1代表查出来数据第一行

九、分布式

在使用Jmeter进行性能测试时,如果并发数比较大(比如项目需要支持1000并发),单台电脑的配置(CPU和内存)可能无法支持,这时可以使用Jmeter提供的分布式测试的功能

一、Jmeter分布式执行原理:

  1、Jmeter分布式测试时,选择其中一台作为调度机(master),其它机器做为执行机(slave)。

  2、执行时,master会把脚本发送到每台slave上,slave 拿到脚本后就开始执行,slave执行时不需要启动GUI,应该是通过命令行模式执行的。

3、执行完成后,slave会把结果回传给master,master会收集所有slave的信息并汇总。

参考:https://www.cnblogs.com/puresoul/p/4844539.html

jmeter csv参数化_jmeter学习(二)相关推荐

  1. jmeter csv参数化_运用Jmeter参数化来实现接口自动化测试

    本文记录如何使用Jmeter参数化(csv)实现接口自动化--测试Token不同入参情况下,接口请求能够返回正确的结果 1. 首先需要使用Jmeter获取一个Token,如何获取暂略(同一般访问请求方 ...

  2. Jmeter CSV 参数化/检查点/断言

    当参数的值没有规律且量不太大时,可以使用CSV Data set config这种方法.  案例:  应用Sogou自动搜索关键字: 软件开发测试,web功能自动化测试,性能自动化测试,Seleniu ...

  3. jmeter csv参数化_性能测试之Jmeter中如何设置参数化数据

    参数化配置 jmeter中进行参数化设置,右击测试计划或者线程组,add->config element->CSV Data Set Config参数1.png Allow quoted ...

  4. jmeter xml 请求_Jmeter学习笔记(十六)——HTTP请求之content-type

    一.HTTP请求Content-Type 常见的媒体格式类型如下: text/html : HTML格式 text/plain :纯文本格式 text/xml : XML格式 image/gif :g ...

  5. jmeter中csv参数化

    Jmeter参数化的方式大概有4种用户定义的变量.用户参数.函数助手.csv文件配置.用户定义的变量与用户参数,两者的用法相似,但用户定义的变量一般作用于脚本全局,用户参数一般用于局部请求:函数助手与 ...

  6. Jmeter系列之常用组件(二)

    VOL 130 01 2020-06 今天距2021年213天 这是ITester软件测试小栈第130次推文 点击上方蓝字"ITester软件测试小栈"关注我,每周一.三.五早上  ...

  7. 聊一聊Jmeter的参数化

    背景 前面一篇聊了一下 JMeter 的简单使用,这篇聊一下 JMeter 的参数化. 在开始之前先来一个单元测试的例子,感受一下参数化. 上面是一个用 xUnit 写的单元测试,这个单元测试就是一个 ...

  8. Jmeter之参数化

    参数化是为了解决什么问题: 当提交的数据量较大时,怎么提交?每测试一次就修改一次吗? 定义: 动态的获取.设置或生成数据,是一种由程序驱动,代替人工驱动的数据设计方案,提高脚本的编写效率以及编写质量 ...

  9. loadrunner之 学习二:loadrunner函数

    学习二:loadrunner函数 一.基础函数 在VU左边导航栏中,有三个LR框架函数,分别是vuser_init(),Action(),vuser_end().这三个函数存在与任何Vuser类型的脚 ...

最新文章

  1. 在Oracle Cloud上的Prime-UI,JAX-RS和Jersey和Gson
  2. 江苏大学考研计算机录取率,报考数据分析—江苏大学
  3. Linux如何修改makefile文件,linux中Makefile的使用
  4. 2k显示无法连接服务器,NBA2K18无法连接服务器怎么办 无法连接服务区解决方法一览...
  5. 《太上感应篇》告诉我们,人的起心动念都得小心啊,哈哈。
  6. python 科研作图_Origin科研绘图
  7. 明翰英语教学系列之雅思篇V1.9(持续更新)
  8. 模板类继承后找不到父类函数的问题
  9. 事件模型-温度预警问题
  10. 客户主数据知识点总结
  11. 【PaddleOCR】Paddle-Lite, Paddle2ONNX介绍, 学习教程...
  12. 如何在线将CAD图纸文件进行转换成黑白PNG格式?
  13. 使用Typora设置图片自动上传至gitee仓库
  14. 品Spring:bean定义上梁山
  15. 基于Kinect体感器控制的机械臂项目记录
  16. 激活Windows 7旗舰版
  17. 小米手机解bl锁正规方法!
  18. 何时对固态盘运行低级格式化或擦除以及使用的工具
  19. 打造政产学研新型研发机构 加速人工智能科研成果转化...
  20. 【C语言】【逻辑非】双感叹号的用法

热门文章

  1. 如何正确处理Android6.0+的运行时权限申请
  2. Zookeeper的功能以及工作原理
  3. SCWS 添加自定义词典
  4. 聊聊 #pragma 和 // MARK:
  5. java导出生成word
  6. HDU 1028 HDU Ignatius and the Princess III
  7. 在Eclipse下面安装spket
  8. oracle 学习小结11
  9. 指针的运用与strcpy函数的优化
  10. .NET 数据访问中间件 HyperDAL v1.1 FAQ