Jmeter配置安装成功后进入就可以看到以下页面
a、测试计划: 名称与注释就是相对于这个测试计划的一些备注信息,在有多个计划的时候方便在结果中查看
b、用户定义变量: 测试计划上可以添加用户定义的变量,一般添加一些系统常用的配置,如果测试过程中想切换环境,切换配置,一般不建议在测试计划上添加变量,一般是直接添加用户自定义变量组建:右击【添加】-【配置原件】-【用户自定义变量】
注:复制过来的变量名及变量值可直接点击【Add from Clipboard】实现粘贴
c、独立运行每一个线程: 如计划下有多个线程组时,勾选后可以保证多个线程的执行顺序,顺序数默认从上往下,如果没有勾选那么计划执行是并行的,且先后顺序不可预料
d、Run tearDown Thread Group after shutdown of main threads: 如果有勾选此项,在测试线程执行失败的时候会执行其他的线程组,没有勾选在测试执行中遇到配置错误则会停止测试,不会执行其他线程
d、函数模式: 如果选中了此项,监听组件如“查看结果树”配置了保存到一个文件中,那么jmeter会将每次请求的结果保存到文件中,一般不勾选
线程组取样错误后执行的动作:
a、继续: 如果取样器里的执行出现错误失败的时候,请求不会停止,继续执行
b、Start Next Thead Loop :忽略错误,线程当前循环错误,执行下一个循环
c、停止线程: 只限当前线程停止,不影响其他线程执行
d、停止测试:当前执行的线程全部执行完毕后结束
e、Stop test Now: 立刻停止测试
线程属性:
a、线程数: 配置线程数时可以实现并发,配合循环可实现压力测试
b、Ramp-up Period(in seconds): 它指定了启动所有线程所花费的时间,如果需要Jmeter立即启动所有线程,将此设定为0即可
c、循环次数: 表示每个线程执行多少次请求
d、Delay Thread creation until needed: 默认不勾选,测试开始的时候,所有线程就被创建完。勾选了此选项,那么线程只会在合适的需要用到的时候创建,可适当减轻些压力
e、调度器:勾选时启用一下的调度器配置信息,否则不启用
调度器配置:在老版本中需要注意的是,“启动延迟”会使“启动时间”无效,而“持续时间”会使“结束时间”无效(此版本页面没有启动时间)
线程组下元件:
a、Sample: 取样器,用来向服务器发送请求
b、逻辑控制器(Logic controller): 用来控制线程执行时的逻辑,能更改它的子元件中的请求的顺序,重复请求等
c、前(Pre processors)、后置处理器(Post processors):前置处理器在取样器请求前执行一些操作。如果前置处理器附有取样器元件,那么它将先于这个取样器元件执行。前置处理器常用于在取样器元件运行前修改它的设置,或是更新从响应文本里提取出来的变量。后置处理器则在取样器请求后执行,多用于处理响应数据,从里面抽取出有价值的东西。
d、断言(Assertions): 断言从被测的服务器端接收到的响应的事实,要查看断言结果,添加断言监听器到这个线程组中
e、定时器(Timer):建意通过添加一个可用的定时器到线程组里来指定延迟时间。如果不添加延时,JMeter可能在较短的时间内发送大量的请求致使服务器瘫痪。
定时器将导致JMeter在线程组里,在每个请求间,延迟一定时间。
f、配置元件(Config Element):工作和取样器很接近,尽管它不能发送请求(HTTP代理服务器除外),它可以补充或修改请求
g、监听器(Listener):监听器可以提供访问JMeter所收集的关于测试用例的信息。图像结果监听器在一个图表里绘制响应时间。查看结果树监听器具体的显示取样器的请求和响应,然后以HTML和XML格式显示出来。其它的监听器提供汇总或组合信息。此外,监听器能处理一个为日后所用,收集到一个文件里的数据。在JMeter里的每个监听器都可以指定一个文件,用来存储数据。
执行顺序:
1–配置元件(Config Element)
2–前置处理器(Pre Processors)
3–定时器(Timer)
4–取样器(sampler)
5–后置处理器(Post Processors,只在有结果可用情况下执行)
6–断言(Assertions,只在有结果可用情况下执行)
7–监听器(Listener,只在有结果可用情况下执行)
1、web服务器
a、协议:向目标服务器发送HTTP请求时的协议,可以是http或者是https或者File ,默认值为http
b、服务器名称:HTTP请求发送的目标服务器名称或IP地址(注意:此处不可带http:/或者https:/如:www.baidu.com即可)
c、端口号:目标服务器的端口号,默认值为80 ,根据实际情况可做更改
2、HTTP请求:
a、方法:发送HTTP请求的方法,可用方法包括GET、POST、HEAD、PUT、OPTIONS、TRACE、DELETE等。
b、路径:目标URL路径(不包括服务器地址和端口)-也可以直接写完整路径(上面的IP+端口就可以省略了)
c、content encoding:内容的编码方式,默认值为iso8859(所以常用为UTF-8减少乱码)
d、自动重定向:选中该选项,当发送HTTP请求后得到的响应是302/301时,JMeter 会自动重定向到新的页面,但是Jmeter是不记录重定向的过程内容。只能用于get和head方法,如果是post或者put请求则取样器不会发送
e、跟随重定向:取样器的默认选项,当响应code是3xx时,自动跳转到目标地址。与自动重定向不同,Jmeter会记录重定向过程中的所有请求响应,在查看结果树时可以看到服务器返回的内容,如有多个跳转则多个请求都会被记录下来
注:自动重定向和跟随重定向的区别只在于是否记录多个跳转的请求上
f、Use KeepAlive:jmeter 和目标服务器之间使用 Keep-Alive方式进行HTTP通信,默认选中
g、Use multipart/form-data for POST:当发送HTTP POST 请求时,使用Use multipart/from-data方法或者application/x-www-form-urlencoded方法发送
h、Browser-compatible headers:当勾选multipart/form-data时,勾选此项会截掉http请求头中的Content-Type和Content-Transfer-Encoding,而只发送Content-Disposition部分
i、Parameter:键值对方式向发送请求的服务器传值
j、Body Data:命令形式向发送请求的服务器传值
k、Files Upload:文件形式向发送请求的服务器传值
1、Client implementation:
a、Implementation:发送http请求的方式,可选项为java和HttpClient4,默认为HttpClient4
2、Timeouts(milliseconds)
a、Connect:连接超时时间,单位为毫秒;
b、Response:响应等待超时时间,单位为毫秒;
3、Embedded Resources from HTML Files
a、从HTML文件获取所有内含的资源:当该选项被选中时,jmeter在发出HTTP请求并获得响应的HTML文件内容后,还对该HTML进行解析 并获取HTML中包含的所有资源(图片、flash等),默认不选中,如果用户只希望获取页面中的特定资源,可以在下方的Embedded URLs must match 文本框中填入需要下载的特定资源表达式,这样,只有能匹配指定正则表达式的URL指向资源会被下载。
b、Parallel downloads.:是否使用自设资源池,勾选后可设置大小;
c、Number:资源池大小,默认为6。
d、URLs must match:URL匹配过滤,填写此项则只会下载与此内容项匹配的url的资源,例如要获取http://example.com/下的所有资源,使用正则表达式http://example.com/.*;
4、Source address
a、Source address:只用于http协议且Implementation为HttpClient4的情况。
此属性用于启用IP欺骗。会重写了这个http请求使用的默认本地IP地址。用于Jmeter主机具有多个IP地址(即IP别名、网络接口、设备)的情况。该值可以是主机名、IP地址或网络接口设备,如“ey0”或“l0”或“wlan0”。
- IP/Hostname:IP /主机名以使用特定的IP地址或(本地)主机名
- Device:选择设备以选择该接口的第一个可用地址,该设备可以是IPv4或IPv6。
- Device IPV4:选择IPv4设备来选择名称设备的IPv4地址(如eth0, lo, em0);
- Device IPV6:选择IPv6设备来选择名称设备的IPv4地址(如eth0, lo, em0);
5、Proxy Server(不想用本机的地址来发送请想使用代理服务器则填写这部分)
服务器名称或IP:代理服务器的名称或者IP地址;
端口号:该代理的端口号;
用户名:使用该代理的用户名;
密码:用户密码;
6、其他任务
Save response as MD5 hash:选中该项,在执行时仅记录服务端响应数据的MD5值,而不记录完整的响应数据。在需要进行数据量非常大的测试时,建议选中该项以减少取样器记录响应数据的开销;
http请求默认值(页面与HTTP请求差不多)
在每次访问的地址(服务器名称或IP)是不变的,端口也是不变的,协议也是不变的(http协议);每个请求都要写一遍,在我们的HTTP请求取样器数量很多的情况下,这种修改的工作量是很大的,可以把测试计划中所有的http请求的默认配置放到HTTP请求默认值(HTTP Request Defaults)中
HTTP信息头管理器:用于管理请求头内容,信息头管理器中设置的值,会被添加到http请求的请求头中发送
HTTPcookie管理器:自动帮你存cookie保持登陆状态
用户定义的变量:自定义变量可以让我们随机选取变量,从而达到在性能测试过程中可以随机选取变量的目的。但是在实际使用中发现一个问题,并不试用于所有场景,比如登录
文件名: 此项包括文件的路径及拓展名,可直接预览选择
文件编码: 给出页面的编码格式,可以不填写,页可以下拉选择
变量名称: 给出变量名如:name,pwd;这里的变量名是给后面引用用的,如要用到这个文件的值,可以利用变量名来引用:${name},${pwd},如test.csv文件中有这样的数据:1@180chen.cn,abc1233,那${name}就可以引用到1@180chen.cn,${pwd}就可以引用到abc1233
忽略首行:设置后文件中的首行数据不读取
分隔符:是用来隔开变量的分隔符,如上面的name,pwd,那分隔符就是“,”
是否允许带引号:设置为true时,文件中的参数值必须用引号括起来
遇到文件读取结束时再次循环:配置为false 当文件读取结束时一直读取最后一行,配置为true时重新从第一行读取
遇到文件读取结束时停止线程:配置为false当文件读取结束时不停止线程,配置为true时停止当前线程测试,当选择再次循环时该配置无效
线程共享:配置取出来的文件可用范围,有All threads---所有线程,Current thread group—当前线程组,Current thread—当前线程
变量名称:在之后用到是使用该变量名称${....}
输出格式:如写入name1,那么在输出的时候就是name1+随机结果
配置随机发生器:均配置为数字,随机种子暂时没发现用法
ps:jmeter中自带的函数比这个控件好用,其中还有很多的其他函数
所有数据写入一个文件:文件名就是把响应的结果树保存到本地的路径文件,文件为xml或jtl格式,可选保存机制 仅日志错误、成功的,默认所有;config可配置察看结果树,勾选所有配置项
search:在输入框中对结果内容进行搜索
case sensitive:勾选则在搜索时区分大小写
regular exp:勾选则标识使用正则表达式进行搜索
search:点击进行搜索,匹配搜素框输入的内容。ps:如果没有对应结果text下不会有任何反应
reset:清空搜索结果
text:此处可调整结果响应的格式,常用的有JSON格式与xml,HTML格式等
正则表达式提取器
apply to :此项选择表达式提取范围,从左至右分别为:匹配当前父取样器及其子取样器、匹配当前父取样器(默认项)、仅匹配子取样器、支持变量进行匹配
要检查的响应字段:
主体:除去header的主体部分
body(UNescaped):针对转义码的body部分
body as a docment:返回内容作为文档进行匹配
信息头:只匹配头部内容
request headers:匹配请求头部内容
url:只匹配URL链接
响应代码:只匹配相应的代码,如相应状态200等
响应信息:匹配相应信息,如“成功”‘OK’等
参数释义
引用名称:在HTTP等请求中,引用此数据,需要用到的名称
正则表达式:用于将需要的数据提取出来,把提取规则写入
模板:表示使用提取到的第几个值:
$-1$:表示取所有值
$0$:表示随机取值
$1$:表示取第1个
$2$:表示取第2个
以此类推:$n$:表示取第n个
匹配数字(0代表随机):0 代表随机取值,1 代表全部取值
缺省值如果正则表达式没有搜找到值,则使用此缺省值,即默认值