jmeter学习(二)

参数说明:

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

b) 正则表达式:

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

    .:匹配任何字符串

    +:一次或多次

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

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

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

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

四、插件管理

Jmeter插件管理plugins-manager.jar 它管理插件包括 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:\BaiduNetdiskDownload\apache-jmeter-4.0\bin

Jmeter -n -t D:\Jmeter-script\招聘登录+查询.jmx -l D:\JmeterTest\resport\result.csv -e -0 D:\JmeterTest\resport\html

五、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

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 204,684评论 6 478
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 87,143评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 151,214评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,788评论 1 277
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,796评论 5 368
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,665评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,027评论 3 399
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,679评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 41,346评论 1 299
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,664评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,766评论 1 331
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,412评论 4 321
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,015评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,974评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,203评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,073评论 2 350
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,501评论 2 343

推荐阅读更多精彩内容

  • 在使用Jmeter进行接口的性能测试时,由于Jmeter 是JAVA应用,对于CPU和内存的消耗比较大,所以,当需...
    燕京博士阅读 4,159评论 0 16
  • 主要文体来自 CDNS:https://www.cnblogs.com/ceshisanren/p/5639895...
    Amano阅读 10,960评论 3 27
  • 互联网压力性能Badboy.Jmeterhttp://itopic.org/jmeter-http-tcp.htm...
    燕京博士阅读 2,883评论 0 20
  • 公司最近需要测试后台性能,所以学习使用了Jmeter,在此做记录,也分享给更多需要的人。 这篇文章是 JMeter...
    顾顾314阅读 4,248评论 0 10
  • 理想,果然是,有点儿丰满???_(:з」∠)_ 还有历史和化学笔记w先宽松地给自己记过_(:з」∠)_ 1.练字√...
    妮可妮可喳阅读 160评论 0 0