jmeter 使用白皮书

1、jmeter中的响应端言html

    断言就相似LoadRunner中的检查点。对上一个请求返回的信息,作字符串、数据包大小、HTML、XML、图片等作判断,确保返回的信息的准确性。正则表达式

    如下只讲解下响应断言步骤,新建一个线程组,线程组中添加一个http请求,添加响应断言:添加-》断言-》响应断言:服务器

    配置说明:    app

apply to:是应用范围,设定匹配的范围ide

Main sample and sub-samples:匹配范围为当前父取样器,及子取样器性能

Main sample only :仅当前父取样器测试

Sub samples only:仅子取样器url

JMeter Variable:变量值进行匹配线程

要测试的响应文字:针对响应数据不一样部分进行匹配翻译

(1)响应文本:响应服务器返回的文本内容,http协议排除header部分

(2)响应代码:匹配响应代码,好比http请求中‘200’表明成功

(3)响应信息:匹配响应信息,处理成功返回‘成功’或者“ok”字样

(4)Response Header:匹配响应头中的信息

(5)Document(Text):一切Apache Tika 支持服务器响应,包括文本响应,还支持 PDF, Office, Audio, Video formats。

(6) url样本:是对sample的url进行断言。若是请求没有重定向(302),那么就是这个就是请求url。 若是有重定向(且跟随重定向),那么url就包含请求url 和 重定向url 

匹配规则:

包括:响应内容包括须要匹配的内容就算成功

匹配:响应内容要彻底匹配匹配内容,不区分大小写

equals:彻底相等,区分大小写

substring:响应内容包括匹配内容即为成功。

 否:就至关于取反。 若是上面断言结果为true,勾选“否”后,最终断言结果为false。若是上面断言结果为false,勾选“否”后,则最终断言结果为 true。 

要测试的模式:这里就须要输入 咱们要匹配的响应接口(即接口测试结果的指望值或者其余指望值) 

能够经过添加断言结果来查看断言的执行状况。

二:正则表达式提取器

      容许用户从做用域内的sampler请求的服务器响应结果中经过正则表达式提取值所需值,生成模板字符串,并将结果存储到给定的变量名中。

       新建一个线程组,线程组中添加一个http请求,添加正则表达式提取器:添加-》后置处理器-》正则表达式提取器: 

      配置说明:      

APPly to:做用范围(返回内容的断言范围)

一、Main sample and sub-samples:做用于主节点的取样器及对应子节点的取样器

二、Main sample only:仅做用于主节点的取样器

三、Sub-samples only:仅做用于子节点的取样器

四、JMeter Variable:做用于jmeter变量(输入框内可输入jmeter的变量名称),从指定变量值中提取须要的值。

Field to check:要检查的响应报文的范围

一、主体:响应报文的主体,最经常使用

二、Body(unescaped):主体,是替换了全部的html转义符的响应主体内容,注意html转义符处理时不考虑上下文,所以可能有不正确的转换,不太建议使用

三、Body as a Document:从不一样类型的文件中提取文本,注意这个选项比较影响性能

四、Response Headers:响应信息头(若是你使用的是中文版的Jmeter,会看到这一项是信息头,这是中文翻译问题,应以英文为准)

五、Request Headers:请求信息头

六、URL:请求url

七、Response Code:响应状态码,好比200、404等

八、Response Message:响应信息

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

  (2)正则表达式:

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

    .:匹配任何字符串。
    +:一次或屡次。
    ?:不要太贪婪,在找到第一个匹配项后中止。

  (3)模板:用$$引用起来,若是在正则表达式中有多个正则表达式,则能够是$2$$3$等等,表示解析到的第几个值给title。如:$1$表示解析到的第1个值

  (4)匹配数字:0表明随机取值,1表明所有取值,一般状况下填0

  (5)缺省值:若是参数没有取获得值,那默认给一个值让它取。

举例说明: 

一、提取单个字符串:
    假如想匹配Web页面的以下部分:name = "file" value = "readme.txt">并提取readme.txt。一个合适的正则表达式:name = "file" value = "(.+?)">。
      ():封装了待返回的匹配字符串。
      .:匹配任何单个字符串。
      +:一次或屡次。
      ?:不要太贪婪,在找到第一个匹配项后中止。

  二、提取多个字符串:
    假如想匹配Web页面的以下部分:name = "file.name" value = "readme.txt">并提取file.name和readme.txt。一个合适的正则表达式:name = "(.+?)" value = "(.+?)"。这样就会建立2个组,分别用于$1$和$2$

  好比:

    引用名称:MYREF
    模板:$1$$2$

   以下变量的值将会被设定:
    MYREF:     file.namereadme.txt
    MYREF_g0:   name = "file.name"value = "readme.txt"
    MYREF_g1:  file.name
    MYREF_g2:  readme.txt

  在须要引用地方能够经过:${MYREF}, ${MYREF_g1进行使用。

 3、简单分析

       a)结果树:

       取样器结果:Response code:200 表示执行接口调试成功;

       请求:发送的数据;

        响应数据:返回的数据;

 Thread Name:线程名称组;

Sample Start:启动开始时间;

Load time:加载时长;

Latency:等待时长;

Size in bytes: 发送的数据总大小;

Headers size in bytes:发送数据的其他部分大小;

Sample Count:发送统计;

Error Count:交互错误统计;

Response code:返回码;

Response message:返回信息;

Response headers:返回的头部信息;

b)聚合报告:

Label:httpRequset Name 属性值;

Samples:测试过程当中一共发出了多少个请求即总线程数,(若是模拟10个用户,每一个用户迭代10次,这里就显示100),对应图形报表中的样本数目;

Average:单个reques的平均响应时间,计算方法是总运行时间除以发送到服务器的总请求数,对应图形报表中的平均值;

Median:50%用户的响应时间;

90%Line:90%用户的响应时间;

Min:服务器响应的最短期;

Max:服务器响应的最长时间;

Error%:本次测试中出错率,请求的数量除以请求的总数;

Throughput:吞吐量--默认状况下表示每秒完成的请求数;

KB/Sec:每秒从服务器接收到的数据量,即每秒钟请求的字节数,时间单位均为ms;

c)图形结果:

样本数目:测试过程当中一共发送了多少个请求即总线程数;

最新样本:表明时间的数字,是服务器响应最后一个请求的时间;

吞吐量:服务器每分钟处理的请求数;

平均值:总运行时间除以发送到服务器的请求数;

中间值:有一半的服务器响应时间低于改值而另外一半高于该值;

偏离:表示服务器响应时间变化、离散程度测量值的大小;

相关文章
相关标签/搜索