#引言

性能测试某种程度上会比自动化更难搞定。代码、运维、计算机原理、数据库、业务等等,你都要搞懂。写脚本或者执行都还好,难的是性能分析和调优。当然如果这个阶段你对自己的要求还不是很高,那么掌握性能测试的基本流程和简单的性能分析就可以了。更多的比如搭建压测环境、监控性能指标等等,还是要在实战中去积累经验的。

#Jmeter压测场景

  • 基准测试:单用户,初步了解下该交易的响应时间和TPS

单场景负载测试:80用户并发,压测10分钟左右,考查单个负载情况。这个场景容易测试出来响应时间慢或者服务器资源利用率高的问题

混合场景容量测试:以客户要求的最低并发数为基准,以一定的梯度递增并发用户数压测混合交易,直至系统出现性能拐点。这个场景主要是考察系统最大的处理能力是多少。

浪涌场景:以系统最优处理能力(资源使用率接近75%-80%,响应时间和tps达标)的并发用户数为最大并发,以系统的资源使用率在20%-30%左右的并发用户数为最小并发,最小并发和最大并发交替运行,每个梯度运行10分钟,共运行一个小时。这个场景考察突然增大或者减少用户数,系统资源会不会上升或下降,主要是看用户数忽然减少时,资源利用率会不会下降。

稳定性测试:确定系统在满足性能指标的前提下长时间运行(12H)是否稳定运行,混合场景下检查各个接口响应时间,吞吐量,应用内存是否存在异常。并发量设置为最优并发量*50%。

  • #工具优点

高性能/提供测试数据分析/各种报表数据图形展示

#快速开始

一、下载安装JDK

1. 下载JDK

  • Java JDK 1.8
  • plugins-manager.jar:将jar包放到lib/ext,重启Jmeter

2. 安装JDK

3. 配置Java安装环境的系统变量

  • 高级系统设置中新建环境变量

aurze devops jmeter 自动化测试 jmeter性能自动化_响应时间

  • 系统设置中新建环境变量JAVA_HOME,变量值选择你的JDK安装目录

aurze devops jmeter 自动化测试 jmeter性能自动化_jmeter_02

  • 系统变量中寻找 Path变量,不要新建覆盖,新建追加%JAVA_HOME%\bin;%JAVA_HOME%\jre\bin
  • 新建CLASSPATH系统变量,变量值填写为.;%JAVA_HOME%\lib;%JAVA_HOME%\lib\tools.jar(注意最前面有一点)

aurze devops jmeter 自动化测试 jmeter性能自动化_响应时间_03

  • 验证JDK是否安装成功,打开cmd,运行java –version,能得到下面的输出就表示配置正确了

aurze devops jmeter 自动化测试 jmeter性能自动化_测试工具_04

 二、下载安装Jmeter

1. 下载Jmeter

  • Jmeter
  • JMeter插件

aurze devops jmeter 自动化测试 jmeter性能自动化_jmeter_05

  • Binaries是可执行版,直接下载解压就可以拿来用的,他已经给你编译好的版本
  • Source 是源代码版,需要自己编译成可执行软件

2. 配置环境变量

  • 同样,高级系统配置中,新建JMETER_HOME,变量值为Jmeter安装路径

aurze devops jmeter 自动化测试 jmeter性能自动化_jmeter_06

  • 追加CLASSPATH,变量值填写%JMETER_HOME%\lib\ext\ApacheJMeter_core.jar;%JMETER_HOME%\lib\jorphan.jar;%JMETER_HOME%\lib\logkit-2.0.jar;

3. Jmeter启动成功

  • 在JMeter安装路径bin文件夹下,找到jmeter.bat文件,双击启动。
  • 启动之后会有两个窗口,Jmeter的命令窗口和Jmeter的图形操作界面,不可以关闭命令窗口

aurze devops jmeter 自动化测试 jmeter性能自动化_测试工具_07

 三、实现性能自动化测试

#场景

测试20个用户,10秒钟,循环5次,访问百度网址查询功能,在负载达到30QPS时的平均响应时间

URL:https://www.baidu.com/s?ie=utf-8&wd=jmeter 

QPS:Query Per Second 每秒查询率。(一台查询服务器每秒能够处理的查询次数,作为域名服务器的性能经常用每秒查询率来衡量

1. 添加线性组

右击test plan ->Add -->Threads(Users)-->Thread Group

输入线程数,准备时长,循环次数

10秒钟启动20个线程,循环次数为5,那么每个线程发送5次请求,总请求数为20*5=100

aurze devops jmeter 自动化测试 jmeter性能自动化_压力测试_08

2. 添加HTTP请求

Thread Group ->Add->Sampler->HTTP Request

aurze devops jmeter 自动化测试 jmeter性能自动化_压力测试_09

aurze devops jmeter 自动化测试 jmeter性能自动化_响应时间_10

  • 在请求中发送的URL参数,用户可以将URL中所有参数设置在本表中,表中每行为一个参数(对应URL中的 name=value),注意参数传入中文时需要勾选“编码

3. 设置QPS限制

Jmeter提供了一个非常有用的定时器,常数吞吐量定时器(Constant Throughput Timer),可控制给定的取样器发送请求的吞吐量

Thread Group ->Add->Timer->Constant Throughput Timer

aurze devops jmeter 自动化测试 jmeter性能自动化_测试工具_11

4. 添加查看结果树

Http->Add->Listener->View Results Tree

  • 修改响应数据格式为HTML Source Formatted

aurze devops jmeter 自动化测试 jmeter性能自动化_压力测试_12

5. 添加用户自定义变量

Thread Group->Add->Config Element->User Defined Variables

aurze devops jmeter 自动化测试 jmeter性能自动化_压力测试_13

6. 添加断言

http ->Add->Assertions->Response Assertion

aurze devops jmeter 自动化测试 jmeter性能自动化_压力测试_14

7. 添加断言结果

http->Add->Listener->Assertion Results

aurze devops jmeter 自动化测试 jmeter性能自动化_响应时间_15

8. 添加聚合报告

http->Add->Listener->Aggregate Report

aurze devops jmeter 自动化测试 jmeter性能自动化_响应时间_16

9. http->Add->Listener->Aggregate Graph

  • 添加Aggregate Graph聚合图表,这个组件是在聚合报告(Aggregate report)的基础之上增加了图形化展示,把数据转化成柱状图的形式展示,并且可以编辑图形展示的样式

10. http->Add->Listener->Response Time Graph

  • 添加Response Time Graph,相应时间图表,这个listener把请求响应时间以折线图的方式展示出来,方便查看
  • 就完成了一个完整Http接口的JMeter性能测试脚本编写,点开始执行测试

10. 执行后结果

  • 先清空,再执行

aurze devops jmeter 自动化测试 jmeter性能自动化_压力测试_17

  •  查看结果树

aurze devops jmeter 自动化测试 jmeter性能自动化_压力测试_18

  • 查看断言结果

aurze devops jmeter 自动化测试 jmeter性能自动化_jmeter_19

  • 查看断言结果聚合报告

aurze devops jmeter 自动化测试 jmeter性能自动化_测试工具_20

  • Aggregate Graph聚合图表

aurze devops jmeter 自动化测试 jmeter性能自动化_自动化_21

 

  • Response Time Graph响应时间图表

aurze devops jmeter 自动化测试 jmeter性能自动化_自动化_22

  •  其中聚合报告页面参数详解: 
  • 1)Label:每个Jmeter的element都有一个Name属性,这里显示的就是Name属性的值
  • 2)#Sample:表示你这次测试中一共发出了多少个请求,如果模拟10个用户,每个用户迭代10次,那么这里显示100
  • 3)Average:平均响应时间-默认情况下是单个Request的平均响应时间当使用了Transaction Controller 时,也可以以Transaction为单位显示平均响应时间
  • 4)Median:中位数,50%用户的响应时间
  • 5)90%Line:90%用户响应时间
  • 6)Min:最小响应时间
  • 7)Max:最大响应时间
  • 8)Error%:本次测试中出现错误的请求的数量/请求的总数
  • 9)Throughput:吞吐量-默认情况下表示每秒的请求数
  • 10)Received KB/sec----每秒从服务器端接收到的数据量
  • 11)Sent KB/sec----每秒从客户端发送的请求的数量