当前位置: 首页 > article >正文

Jmeter性能测试

Jmeter性能测试

一、性能测试介绍

1、什么叫做性能测试?


(1)通过某些工具或手段来检测软件的某些指标是否达到了要求,这就是性能测试
(2)指通过自动化的测试工具模拟多种正常、峰值以及异常负载条件来对系统的各项性能指标进行测试

2、性能测试的时间?

在功能测试完成后才能进行性能测试

3、为什么要做性能测试?


(1)评估系统的能力,
(2)识别体系中的弱点
(3)验证稳定性
(4)系统调优


4、性能测试的流程?

(1)性能需求分析 (标准)

(2)性能计划的编写
(3)性能场景的设计
(4)脚本的开发(录制脚本)
(5)性能环境和数据
(6)性能执行

(7)结果分析(是否标准)
(8)性能总结报告

(9)性能调优

5、性能的类型有哪些?

(1)基准测试
在给系统施加较低压力时,查看系统的运行状况并记录相关数作为基础参考
(2)负载测试(慢慢接近临界点测试)

负载测试是对被测系统不断增加压力(即用户并发数),直至性能指标超过预期或者某项资源使用达到饱和状态(就是加压到系统崩溃)

(3)压力测试(也称为破坏性测试)(超过临界点测试)
压力测试:压力测试是系统在一定饱和状态下,例如cpu、内存、磁盘I/O在饱和使用情况下,不断给系统施加压力,看系统的处理能力,以及系统是否会出现错误。
(4)稳定性测试
稳定性测试是在给系统施加一定压力,持续运行一段时间(7*24),观察系统能否稳定运行。(也可以说是长时间的压力测试)

(5)并发测试
并发测试:并发测试是模拟多用户并发访问同一个应用、模块或者数据记录时可能发生的性能问题(如内存泄漏、线程锁和资源占用方面的问题)

 6、性能测试常用的工具有哪些?


(1)jmeter   轻量级工具,免费,开源, (我们讲解的)
(2)loadrunn   商业版,收费,不易于安装,一个包4g包


7、性能测试文档包含哪些?


(1)性能测试测试计划

(2)性能场景设计用例

(3)性能报告

8、性能测试报告包含哪些内容?


(1)测试背景
(2)测试目的
(3)测试范围
(4)测试环境
(5)压测指标
(6)性能测试结果

(7)性能问题归纳

(8)性能调优

图片

二、熟悉性能报告

图片

 2. 性能问题

    •       (1) 提现申请接口3-5个线程并发时,容易引起死锁现象,经优化后,Tps达到224左右,且没有死锁现象出现;
    •           (2) 账单查询接口,优化索引前,响应时间为8s左右,Tps为11;优化索引后,响应时间缩短为0.15秒左右,Tps升为560左右



三、认识jmeter



(1)jmerer是一个什么工具?


Apache JMeter是Apache组织开发的基于Java的压力测试工具。用于对软件做压力测试,它最初被设计用于Web应用测试,但后来扩展到其他测试领域。 

(2)详细讲解jmeter目录下常用文件有哪些? 


bin目录:核心可执行文件
jmeter.bat:windows启动文件
 

图片

jmeter-server.bat:分布式压测使用的启动文件 

图片

jmeter.properties:核心配置文件 examples(例子):该目录下存放Jmeter官方给的请求模板

图片



report-template(报告模板):该目录下存放Jmeter的报告模板 templates(模板):该目录下存放Jmeter的各类配置模板 例如:JDBC、Beanshell等 

图片

(3)性能测试是生产环境还是测试环境?


性能测试要搭建性能环境,(不在测试环境和生产环境进行性能测试) 因为性能环境考验模拟线上环境,达到1:1比例; 通过造数据,jmeter 造大量数据,存储造大量数据 


(4)jmeter 作性能测试的缺点?


jmeter 的缺点是压力值不能精确控制,难以适应高并发情况,由于是java编写,本身比较消耗资源。 

(5)jmeter和loadrunner 的区别?


a.loadrunner 是一种预测系统行为和性能的负载测试工具。

b.loadrunner 能够最大限度地缩短测试时间,优化性能和加速应用系统的发布周期的商业工具 

c、jmeter 是开发源代码项目,可以进行接口测试和性能测试的工具,
d、相对loadrunnrt是一个轻量级的工具,便于安装

 

获取接口的方式:

第一种:

抓包:写入接口fiddler或f12

图片

第二种方式 :

录制脚本工具badboy 录制

1.点击安装包

图片

图片

图片

2.快捷方式到桌面

图片

图片

3.点击打开badoy

图片

4.导出接口

图片

图片

5.将录制的接口导入到jmeter种

图片

图片

图片

第三种方式:

jmeter中有反向代理录制脚本

1.工作中添加http代理服务器

图片

2.编辑代理服务器

图片

(1)端口号

端口:

默认为8888,可修改。但要注意,端口不能被其它程序占用,端口信息要与浏览器设置保持一致。

cmd.exe中使用如下命令检查端口使用情况:

1)netstat -an    --列出本机所有使用端口信息

2)netstat  -aon|findstr "8888"  --查询端口是否被占用

3)tasklist|findstr "8888"  --查询对应端口被什么程序占用

端口号:8888(默认)改成不常用的端口号避免端口号冲突;如8800

目标控制器:使用录制控制器(默认)后面根据情况进行更改

图片

如上就是没有占用

2.操作浏览器(打开浏览器)

图片

3.打开代理,填写参数

图片

图片

4.开启jmeter中的代理

图片

5.启动后就在页面访问,录制到接口

图片

图片

以上是录制了所有的功能

要录制的要排除不需要的接口

图片

测试计划 -> http代理服务器 -> requests filtering -> 排除模式 ,录制时排除在外的内容:

.*\.(js|css|PNG|jpg|ico|png|gif).*

图片

图片

实战性能

1.单接口性能测试(同一用户进行压力测试)

POST http://49.233.201.254:8080/cms/manage/loginJump.do

POST data:

userAccount=admin&loginPwd=123456

图片

按100 压力测试

(1)在线程中修改虚拟用户数

图片

图片

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

Ramp-Up Period(in seconds)准备时长:设置的虚拟用户数需要多长时间全部启动。如果线程数为10,准备时长为2,那么需要50秒钟启动500个线程,也就是每秒钟启动10个线程。

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

Delay Thread creation until needed:直到需要时延迟线程的创建。

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

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

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

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

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

(2)添加查看结果树

图片

(3)添加聚合报告

图片

图片

聚合报告参数详解:

Label:每个 JMeter 的 element(例如 HTTP Request)都有一个 Name 属性,这里显示的就是 Name 属性的值

#Samples:请求数——表示这次测试中一共发出了多少个请求,如果模拟10个用户,每个用户迭代10次,那么这里显示100

Average:平均响应时间——默认情况下是单个 Request 的平均响应时间,当使用了 Transaction Controller 时,以Transaction 为单位显示平均响应时间

Median:中位数,也就是 50% 用户的响应时间

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

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

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

Min:最小响应时间

Max:最大响应时间

Error%:错误率——错误请求数/请求总数

Throughput:吞吐量——默认情况下表示每秒完成的请求数(Request per Second),当使用了 Transaction Controller 时,也可以表示类似 LoadRunner 的 Transaction per Second 数

KB/Sec:每秒从服务器端接收到的数据量,相当于LoadRunner中的Throughput/Sec

一般而言,性能测试中我们需要重点关注的数据有:

#Samples 请求数,Average 平均响应时间,Min 最小响应时间,Max 最大响应时间,Error% 错误率及Throughput 吞吐量

2.单接口性能测试(不同用户进行压力测试)

(1)登录接口设置变量

图片

(2)后台造数据用户(10个)

(3)通过前置处理中的用户参数或csv data config

图片

(4)在线程中设置虚拟用户

图片

(5)查看结果树,聚合报告,图形报告,表格报告

图片

(6)查看结果树结果

图片

(7)聚合报告

图片

(8)表格报告

图片

(9)图形报告

图片

3.一个场景的接口测试(压力测试同一用户)

一个场景:登录接口,

POST http://49.233.201.254:8080/cms/manage/loginJump.do

POST data:

userAccount=admin&loginPwd=123456

用户查询成功

POST http://49.233.201.254:8080/cms/manage/queryUserList.do

POST data:

startCreateDate=&endCreateDate=&searchValue=&page=1

(1)将两个接口填入到jmeter 或录制到jmeter中

图片

(2)将接口调通:

加cookie,加请求头等

图片

(3)填写虚拟用户数和等待时间

图片

图片

性能场景测试

一、不同用户一个场景压力测试

1.更改变量 

图片

2.前置处理中添加用户参数,导入用户

图片

图片

3.填写查询用户接口

图片

4.接口有依赖关系,添加cookie值

图片

5.添加查看结果树,聚合报告等

图片

二. 并发测试

同一时间,同一个点进行接口测试

图片

图片

集合点的概念:

loadrunner中集合点可以设置多个虚拟用户等待到一个点,同时触发一个事务,以达到模拟真实环境下多个用户同时操作实现性能测试的最终目的。jmeter

中使用Synchronizing Timer实现Lr中集合点的功能,模拟多用户并发测试,即多个线程在同一时刻并发请求。

1、线程组右键 -> 定时器 -> Synchronizing Timer

2、参数设置

a. Number of Simulated Users to Group by: 此处填写并发数量

b. Timeout in milliseconds: 超时时间设置

Jmeter默认没有超时时间,如果没有设置,一旦没有达到集结数量的请求系统就一直

等待。

图片

计算超时时间方法参考:

并发数量 * 1000毫秒/ 线程数/在多少时间启动这么多线程

10*1000/(10/10)=10000

定时器作用域:

作用于该定时器之后的所有请求,也就是说定时器实在请求执行前起作用的并发数和线程数一致时,并发启动时间,一定要大于线程组启动,如果小于这个时间,并发数量不准确。

(注意:线程组整理的启动时间单位是秒,定时器里的等待时间是:毫秒 ,哟啊注意单位换算,1秒=1000毫秒)

图片

三.基准测试

较小的压力进行性能测试

图片

图片

四.稳定性测试

图片


http://www.kler.cn/a/614423.html

相关文章:

  • 硅基流动的api_key可以跑通OpenManus 完整配置
  • Imgui处理glfw的鼠标键盘的方法
  • 1--当「穷举」成为艺术:CTF暴力破解漏洞技术从入门到入刑指南(知识点讲解版)
  • Python爬虫:开启数据抓取的奇幻之旅(一)
  • MyBatis基础三(注解开发)
  • RabbitMQ高级特性--重试特性
  • 28_跨域
  • 并发编程模型
  • QT登录注册模块(客户端)
  • [特殊字符]《多商户家政系统技术解析:SpringBoot+MyBatisPlus+UniApp高效实战指南》
  • 力扣刷题494. 目标和
  • Linux环境下安装部署Docker
  • (二)创建实例
  • 去噪算法大比拼
  • Vite任意文件读取漏洞:CVE-2025-30208
  • DeepSeek-R1国产大模型实战:从私有化部署到内网穿透远程使用全攻略
  • HCIP之VRRP
  • ETL与数据迁移:从传统系统到云平台的平稳过渡全攻略
  • 【磁盘扩容】linux磁盘扩容
  • 【QA】QT有哪些状态模式的设计?