Jmeter相关文档与练习

          JMeter软件测试

一、性能测试

1.性能测试是什么?

性能指标关注点:时间性能、空间性能

性能测试定义:指通过自动化的测试工具模拟多种正常、峰值以及异常负载条件来对系统的各项性能指标进行测试。

2. 性能测试类型

a.        基准测试:在给系统施加较低压力时,查看系统的运行状况并记录相关数做为基础参考

b.        负载测试:是指对系统不断地增加压力增加一定压力下的持续时间,直到系统的某项或多项性能指标达到安全临界值,例如某种资源已经达到饱和状态等 。

c.        压力测试:压力测试是评估系统处于或超过预期负载时系统的运行情况,关注点在于系统在峰值负载或超出最大载荷情况下的处理能力。

d.        稳定性测试(可靠性测试):在给系统加载一定业务压力的情况下,使系统运行一段时间,以此检测系统是否稳定。24X3小时

e.        并发测试:测试多个用户同时访问同一个应用、同一个模块或者数据记录时是否存在死锁或者其他性能问题。

3.性能测试工具

二、Jmeter简介

1. Jmeter的基本概念

Apache JMeter是Apache组织开发的基于Java的压力测试工具。

2. 我们为什么使用Jmeter

开源,免费,基于Java编写,可集成到其他系统可拓展各个功能插件

支持接口测试压力(负载和压力)测试等多种功能,支持录制回放(可用badboy进行录制)

入门简单相较于自己编写框架活其他开源工具,有较为完善的UI界面,便于接口调试

多平台支持,可在Linux,Windows,Mac上运行

支持多协议

3. Jmeter的作用

a.        接口测试

b.        性能测试

c.        压力测试

d.        Web自动化测试

e.        数据库测试

4.Jmeter下载地址

Windows下Jmeter下载安装

登录 http://jmeter.apache.org/download_jmeter.cgi ,根据自己平台,下载对应文件

5.安装JAVA环境

点击电脑属性,选择高级系统设置,选择环境变量。点击DEll的新建环境变量,将对应的变量名和值输入进去。

点击Path,将标记的输入进去即可。

6.Jmeter的目录结构

/bin 目录(常用文件介绍)

examples:目录下包含Jmeter使用实例

ApacheJMeter.jar:JMeter源码包

jmeter.bat:windows下启动文件

jmeter.sh:Linux下启动文件

jmeter.log:Jmeter运行日志文件

jmeter.properties:Jmeter配置文件

jmeter-server.bat:windows下启动负载生成器服务文件

jmeter-server:Linux下启动负载生成器文件

/docs目录——Jmeter帮助文档

/extras目录——提供了对Ant的支持文件,可也用于持续集成

/lib目录——存放Jmeter依赖的jar包,同时安装插件也放于此目录

/licenses目录——软件许可文件,不用管

/printable_docs目录——Jmeter用户手册

三、使用Jmeter测试快速入门

1. 线程组是什么

进程:  一个正在执行的程序对应一个进程  

线程:  一个进程有多个执行线程

线程组:     按照线程性质对线程分组

三者关系: 一个进程有多个线程组,一个线程组有多个线程

测试计划—线程组—线程组属性中的线程数

并发执行:多个线程同时执行,特点:执行结束的顺序与开始的顺序不一致

顺序执行:按照线程的启动顺序挨个执行

默认情况下,线程组中的线程是并发执行

每一个线程都要执行组内的http请求

设置线程组顺序执行:勾选测试计划中的(独立运行每个线程组)

线程组用来模拟用户的并发访问

1.1.创建线程组

线程组主要包含三个参数:线程数、准备时长(Ramp-Up Period(in seconds))、循环次数

1.1.3. 线程数:虚拟用户数。一个虚拟用户占用一个进程或线程。设置多少虚拟用户数在这里也就是设置多少个线程数。

1.1.4. 准备时长(秒):设置的虚拟用户数需要多长时间全部启动。如果线程数为20 ,准备时长为10 ,那么需要10秒钟启动20个线程。也就是每秒钟启动2个线程。

1.1.5.  循环次数:每个线程发送请求的次数。如果线程数为20 ,循环次数为100 ,那么每个线程发送100次请求。总请求数为20*100=2000 。如果勾选了“永远”,那么所有线程会一直发送请求,一到选择停止运行脚本。

1.1.6.  调度器:设置线程组启动的开始时间和结束时间(配置调度器时,需要勾选循环次数为永远)

1.1.7.  持续时间(秒):测试持续时间,会覆盖结束时间

1.1.8.  启动延迟(秒):测试延迟启动时间,会覆盖启动时间

1.1.9.  启动时间:测试启动时间,启动延迟会覆盖它。当启动时间已过,手动只需测试时当前时间也会覆盖它。

1.1.10.结束时间:测试结束时间,持续时间会覆盖它。

2. 创建http请求

3.指定请求域名,请求路径

4.设置对应的查看内容

5.查看表格信息

 

 

6.查看结果树

通过察看结果树,我们可以看到每个请求的结果,其中红色的是出错的请求,绿色的为通过

Thread Name:线程组名称

Sample Start: 启动开始时间

Load time:加载时长

Latency:等待时长

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

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

Sample Count:发送统计

Error Count:交互错误统计

Response code:返回码

Response message:返回信息

Response headers:返回的头部信息

7. 聚合报告参数说明

8.  图形结果

样本数目:总共发送到服务器的请求数。

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

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

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

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

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

四、Jmeter主要组件介绍

1.测试计划是使用 JMeter 进行测试的起点,它是其它 JMeter 测试元件的容器。

2.线程组:代表一定数量的并发用户,它可以用来模拟并发用户发送请求。实际的请求内容在Sampler中定义,它被线程组包含。可以在“测试计划->添加->线程组”来建立它,然后在线程组面板里有几个输入栏:线程数、Ramp-Up Period(in seconds)、循环次数,其中Ramp-Up Period(in seconds)表示在这时间内创建完所有的线程。如有8个线程,Ramp-Up = 200秒,那么线程的启动时间间隔为200/8=25秒,这样的好处是:一开始不会对服务器有太大的负载。线程组是为模拟并发负载而设计。

3、取样器(Sampler):模拟各种请求。所有实际的测试任务都由取样器承担,存在很多种请求。如:HTTP 、ftp请求等等。

4、监听器:负责收集测试结果,同时也被告知了结果显示的方式。功能是对取样器的请求结果显示、统计一些数据(吞吐量、KB/S……)等。

6、断言:用于来判断请求响应的结果是否如用户所期望,是否正确。它可以用来隔离问题域,即在确保功能正确的前提下执行压力测试。这个限制对于有效的测试是非常有用的。

7、定时器:负责定义请求(线程)之间的延迟间隔,模拟对服务器的连续请求。

5、逻辑控制器:允许自定义JMeter发送请求的行为逻辑,它与Sampler结合使用可以模拟复杂的请求序列。

8. 配置元件维护Sampler需要的配置信息,并根据实际的需要会修改请求的内容。

9. 前置处理器和后置处理器负责在生成请求之前和之后完成工作。前置处理器常常用来修改请求的设置,后置处理器则常常用来处理响应的数据。

1.测试计划

1.测试计划就是一个完整的场景

2.“独立运行每个线程组” :勾选以后所有的线程组都是顺序执行的了。一般不勾选,让所有 的线程组并发启动。

3. “函数测试模式” :勾选后会有详细的请求记录,消耗资源,影响客户端性能。一般不勾选。

4.用户定义的变量:全局变量,测试计划上可以添加用户定义的变量。一般添加一些系统常用的配置。如果测试过程中想切换环境,切换配置,一般不建议在测试计划上添加变量

2. 线程组

(1)thread group(线程组)

  这个就是我们通常添加运行的线程。通俗的讲一个线程组,可以看做一个虚拟用户组,线程组中的每个线程都可以理解为一个虚拟用户。

(2)setup thread group

  一种特殊类型的ThreadGroup的,可用于执行预测试操作。这些线程的行为完全像一个正常的线程组元件。不同的是,这些类型的线程执行测试前进行定期线程组的执行;类似LoadRunner的init,测试开始时进行初始化的工作。

(3)teardown thread group

一种特殊类型的ThreadGroup的,可用于执行测试后动作。这些线程的行为完全像一个正常的线程组元件。不同的是,这些类型的线程执行测试结束后执行定期的线程组;类似LoadRunnner的end,测试结束时进行回收工作。

3.取样器(HTTP请求)

关于http请求的的属性参数说明:

 

1)名称:用于标识一个sample。建议使用一个有意义的名称

 

2)注释:对于测试没任何影响,仅用来记录用户可读的注释信息

 

3)服务器名称或IP:http请求发送的目标服务器名称或者IP地址,比如http://www.baidu.com

 

4)端口号:目标服务器的端口号,默认值为80,可不填

 

5)协议:向目标服务器发送http请求时的协议,http/https,大小写不敏感,默认http

 

6)方法:发送http请求的方法(链接:http://www.cnblogs.com/imyalost/p/5630940.html)

 

7)Content encoding:内容的编码方式(Content-Type=application/json;charset=utf-8)

 

8)路径:目标的URL路径(不包括服务器地址和端口)

 

9)自动重定向:如果选中该项,发出的http请求得到响应是301/302,jmeter会重定向到新的界面

 

10)Use keep Alive:jmeter 和目标服务器之间使用 Keep-Alive方式进行HTTP通信(默认选中)

 

11)Use multipart/from-data for HTTP POST :当发送HTTP POST 请求时,使用

 

12)Parameters、Body Data以及Files Upload的区别:

 

   1. parameter是指函数定义中参数,而argument指的是函数调用时的实际参数

 

   2. 简略描述为:parameter=形参(formal parameter), argument=实参(actual parameter)

 

   3.在不很严格的情况下,现在二者可以混用,一般用argument,而parameter则比较少用

 

   While defining method, variables passed in the method are called parameters.

 

   当定义方法时,传递到方法中的变量称为参数.

 

   While using those methods, values passed to those variables are called arguments.

 

   当调用方法时,传给变量的值称为引数.(有时argument被翻译为“引数“)

 

   4、Body Data指的是实体数据,就是请求报文里面主体实体的内容,一般我们向服务器发送请求,携带的实体主体参数,可以写入这里

 

   5、Files Upload指的是:从HTML文件获取所有有内含的资源:被选中时,发出HTTP请求并获得响应的HTML文件内容后还对该HTML

 

      进行Parse 并获取HTML中包含的所有资源(图片、flash等):(默认不选中)

 

      如果用户只希望获取特定资源,可以在下方的Embedded URLs must match 文本框中填入需要下载的特定资源表达式,只有能匹配指定正则表达式的URL指向资源会被下载

4.监听器

监听器(Listener)负责收集测试结果,同时也被告知了结果显示的方式。我们常用的包括:聚合报告、查看结果树、用表格查看结果,都支持将结果数据写入文件。其他的添加上去看看就行。聚合报告前面我们介绍过,后面是查看结果树和用表格查看结果的截图。

5. 逻辑控制器

6. 循环控制器、事务控制器

6.1.循环控制器

6.2.   事务控制器

作用: 事务控制器会生产一个额外的采样器,用来统计该控制器子结点的所有时间。

在线程组下创建事务控制器

参数:

·         Generate parent sample:(选中这个参数结果展示如下图红框,否则显示为下图蓝框)

·         Include duration of timer and pre-post processors in generated sample:选中这一项会统计定时器(timer)的时间,否则只统计采样器(sample)的时间

7. 断言---检查点

断言(Assertions)可以用来判断请求响应的结果是否如用户所期望的。它可以用来隔离问题域,即在确保功能正确的前提下执行压力测试。这个限制对于有效的测试是非常有用的。

五、Jmeter数据库压力测试

1、启动jmeter,打开界面工具,添加一个线程组,添加驱动

2.添加一个JDBC Connection Configuration,连接池配置文件。右键线程组【添加】--【配置元件】--【JDBC Connection Configuration】

原文地址:https://www.cnblogs.com/csdnxc/p/14091225.html