接口压力测试 jmeter--入门篇(一)

一 压力测试的目的

  • 评估系统的能力
  • 识别系统的弱点:瓶颈/弱点
  • 检查系统的隐藏的问题
  • 检验系统的稳定性和可靠性

二 性能测试指标以及测算

  • 【虚拟用户数】:线程=用户
  • 【并发数】:指在某一时间,一定数量的虚拟用户同时对系统的某个功能进行交互。一般通过集合点实现。
  • 【事务】:一个接口可以是事务,多个接口也可以是事务,一个流程可以是事务,事务代表一个完整的功能。由测试人员决定。
  • 【场景】:性能测试的用例
  • 【响应时间】:Response Time

平均响应时间:

  中位数:从小到大排序,选择第50个。

  90%:100 个,从小到大排序,选择第90个。

  95%:从小到大排序,选择第95个。

  99%:从小到大排序,选择第99个。

  基准测试:1个用户请求接口。200-500MS

  压力测试:N个用户并发请求接口,2秒

  • 【TPS】TPS是系统的重要性能指标,用于衡量系统在一定时间内能够处理的事务数(交易数)。(一般在银行中经常看到 TPS)

每秒完成的事务数:Transactions per sencond

如果是一个接口的话,TPS=吞吐量。(多个接口的话不同)

计算公式:总的事务数/总的运行时间

比如1:某一系统1分钟处理1000个事务,那么 TPS=1000/60=16.7

比如2:按去年的经营数据,2022年最高的一天有10万笔交易。预测2023年TPS需要多少合格?

总事务数=10万,时间=24*60*60=86,400秒

理论上TPS = 100000/86400=1.2

(1)没有更详细的数据:根据二八定律(80%的事务在20%的时间完成)计算:

TPS = 100000*0.8 / 86400*0.2=80000/17280=4.6

(2)如果有更详细的数据:

  • 5万比交易是晚上的8-9点完成的。

         TPS=50000/3600=13.9

  • 业务的增长:30%

       TPS=(50000+50000*0.3)/3600=18

  • 【QPS】每一秒的查询率。

    TPS(每秒的事务数),QPS(一般是用于数据处理),RPS(每一秒的请求), HPS(每一秒的点击率)

         如果一个事务只有一个接口,那么TPS=QPS=RPS

  • 【吞吐量】衡量网络成功传输的数量量,单位Byte/S
  • 【资源利用率】服务器:CPU,内存,磁盘,网络。

三 性能测试流程

1. 需求分析以及需求确定(指标值,场景,环境,人员)

一般提性能需求的(以下是否合理?测试人员要有自己的分辨能力):

  • 客户:OA项目,1万员工,并发一万。
  • 产品经理:单台阿里云服务器。支撑1万并发。
  • 项目组领导:3年之后需要达到什么样的性能。

2. 性能测试计划和方案制定。

  • 基准测试
  • 负载测试
  • 压力测试
  • 稳定性测试
  • 其他:配置测试,极限测试,浪涌测试?

3. 性能测试准备阶段

人力,硬件,软件,环境折算(不是很准确)。

一个很重要的:干净(环境/版本等一致,和生产环境一模一样最好)

4. 测试执行阶段

  • 脚本生成和增强
  • 场景设计
  • 指标监控
  • 性能瓶颈定位和性能调优
  • php+nginx+mysql+centos

5. 测试报告和总结

四 脚本的生成(通过jmeter代理服务器录制脚本)

jmeter安装 mac版

jmeter安装windows版

1. 设置代理

  • windows设置客户端的代理

控制面板-->Internet选项-->连接-->局域网设置-->勾上代理输入,jmeter所在电脑的ip(通过cmd-ipconfig查询)和8888端口。(或其他端口也行,只要和 jmeter保持一致。8080/8889 等都可以)

端口占用情况:

netstat -a| findstr “端口号”
  • mac设置客户端代理(通过jmeter设置)

mac所在电脑的ip查询 ipconfig getifaddr en0

端口占用情况:

sudo lsof -i tcp:port  //查看占用情况
sudo kill -9 PID  //杀进程

系统设置--网络--高级--代理--网页代理

2. 设置 jmeter代理服务器

4.2.1 设置Requests Filtering

   接口url:

http://47.107.116.139/phpwind/

4.2.2 设置Test Plan Creation

3. 启动代理(导入证书)

a. 生成ApacheJMeterTemporaryRootCA.crt

点击“启动”出现下面的情况,ok会在jmeter/bin下生成ApacheJMeterTemporaryRootCA.crt

b. 导入jmeter安全证书

菜单选项--ssl管理器--导入上一步生成的证书

c.   浏览器导入证书

上述证书在 jmeter安装目录的bin中

4. 录制脚本

步骤一 访问首页

步骤二 登录-版块--新板块--发帖--回贴--退出

录制的脚本如下:

****然后就可以关闭代理了****

五 脚本的增强

1.查看结果数

添加--监听器--查看结果树

      运行所有的脚本


查看结果数中每个接口的响应是否正确,通过校验后,操作下面的步骤

2.正则表达式

访问接口增加正则表达式

增加csrf_token

(用正则表达式),因为响应数据中的csrf_token在后续的登录中会用到

"csrf_token" value="031fda279957e9b2"

"csrf_token" value="(.*?)"

调用${csrf_token}

3. 函数助手对话框--urldecode

“3.登录接口”的响应数据中,有个网站不大理解,可以通过网址解析函数助手对话框--urldecode

http%3A%2F%2F47.107.116.139%2Fphpwind%2Findex.php%3Fm%3Du%26c%3Dlogin%26a%3Dwelcome%26_statu%3DTXRGbmJET0g0QnVIRkVidUphRURSQkxuMFVIZWk5MVV0SDFnWU4lMkJ3RjZ6SUdzalFsRyUyRlJvWTZlVWVQRjEwbXV3aTUzb25nJTJCb3hBJTNEfGh0dHA6Ly80Ny4xMDcuMTE2LjEzOS9waHB3aW5kL3w

由上图可以看出:

符号解析
%3A
%2F/
%2F%2F//
%3D=

_statu%3D(.*?)"

4. 函数助手对话框--增加随机内容

发帖时,为了不重复,增加随机内容

函数助手对话框--RandomString

5. unicode编码解析

登录 unicode解析网站

  

6. 增加固定定时器

原因:

回贴接口右键--添加--定时器--固定定时器

7. 给指定的帖子回贴

为了给自己发的贴回贴,则将发帖后的 tid用正则表达式提取出来

发帖后响应的内容:

提取tid

tid%(.*?)%

8. 删除不需要的端口

全部运行一遍:

检查都正常,删除有些不需要被禁用的端口,以及------------部分,重新编号,然后再次运行

9. HTTP请求默认值

线程组右键--添加--配置元件--HTTP请求默认值

然后,各接口的web服务器部分可以清除

10. 重定向

下面这种情况是重定向的情况,在接口中设置的是“跟随重定向”

如果不显示重定向,那么就设置“自动重定向”

运行结果:

跟随重定向和自定义重定向,不影响性能

11. HTTP请求头管理

每个接口都有请求头,太多了,可以先禁用掉,再运行,如果没有报错,那么就可以删掉,如果报错了,那么就需要保留。

12. 用户定义的变量

添加--配置原件--用户定义的变量

调用$(fid)

13. 响应时间设置

http请求默认值-高级--响应

设置后,响应时间超过 50ms的就会报错

token:一般用于鉴权

JMeter的聚合报告中的吞吐量==TPS

六 简单的性能测试

设置线程属性

运行结果

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/824237.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

OpenMesh 网格平均曲率计算

文章目录 一、简介二、实现代码三、实现效果参考资料一、简介 根据 Laplace-Beltrami 算子与平均曲率法向的关系: 又根据余切 Laplace-Beltrami 算子的定义: 其中 Ai 为该点邻域面积,取 Voronoi cell 面积如下: 得到

PACNet CellNet(代码开源)|bulk数据作细胞分类,评估细胞命运性能的一大利器

文章目录 1.前言2.CellNet2.1CellNet简介2.2CellNet结果 3.PACNet3.1安装R包与加载R包3.2加载数据3.3开始训练和分类3.4可视化分类过程3.5可视化分类结果 4.细胞命运分类和免疫浸润比较 1.前言 今天冲浪看到一个细胞分类性能评估的R包——PACNet,它与转录组分析方法…

Prometheus + Grafana 搭建监控仪表盘

目标要求 1、需要展现的仪表盘: SpringBoot或JVM仪表盘 Centos物理机服务器(实际为物理分割的虚拟服务器)仪表盘 2、展现要求: 探索Prometheus Grafana搭建起来的展示效果,尽可能展示能展示的部分。 一、下载软件包 监控系统核心…

Spring Cloud Gateway集成聚合型Spring Boot API发布组件knife4j,增强Swagger

大家都知道,在前后端分离开发的时代,前后端接口对接是一项必不可少的工作。 可是,作为后端开发,怎么和前端更好的配合,才能让自己不心累、脑累,直接扔给前端一个后端开放api接口文档或者页面,让…

Unity之OpenXR+XR Interaction Toolkit快速监听手柄任意按键事件

前言 当我们开发一个VR时,有时希望监听一个手柄按键的点击事件,或者一个按钮的Value值等。但是每次有可能监听的按钮有不一样,有可能监听的值不一样,那么每次这么折腾,有点累了,难道就没有一个万能的方法,让我可以直接监听我想要的某个按钮的事件么? 答案是肯定的,今…

分类算法——朴素贝叶斯(四)

概率基础 1概率定义 概率定义为一件事情发生的可能性 扔出一个硬币,结果头像朝上 P(X):取值在[0,1] 2女神是否喜欢计算案例 在讲这两个概率之前我们通过一个例子,来计算一些结果: 问题如下: 1、女神喜欢…

sql知识总结二

一.报错注入 1.什么是报错注入? 这是一种页面响应形式,响应过程如下: 用户在前台页面输入检索内容----->后台将前台输入的检索内容无加区别的拼接成sql语句,送给数据库执行------>数据库将执行的结果返回给后台&#xff…

2024第十五届蓝桥杯JavaB组省赛部分题目

目录 第三题 第四题 第五题 第六题 第七题 第八题 转载请声明出处,谢谢! 填空题暂时可以移步另一篇文章:2024第十五届蓝桥杯 Java B组 填空题-CSDN博客 第三题 第四题 第五题 第六题 第七题 第八题 制作不易,还请点个赞支持…

数据结构-栈和队列刷题集(长期更新)

文章目录 万能计算器的实现以及源码分析1. leetcode 150 逆波兰表达式求值 万能计算器的实现以及源码分析 /*** 我们尝试写一个完整版的计算器,由于计算机不能很好的识别括号,所以一般要转换为逆波兰表达式求解* 思路解析 :* 1. 输入一个 中缀表达式* 2. 中缀表达式转化为list…

SpringBoot基于RabbitMQ实现消息可靠性

文章目录 1. ☃️概述2. ☃️生产者消息确认2.1 ❄️❄️概述2.2 ❄️❄️实战⛷️⛷️⛷️2.2.1 修改配置⛷️⛷️⛷️2.2.2 定义 Return 回调⛷️⛷️⛷️2.2.3 定义ConfirmCallback 3. ☃️消息持久化3.1 ❄️❄️交换机持久化3.2 ❄️❄️队列持久化3.3 ❄️❄️消息持久化…

进程、线程和协程

进程、线程和协程 进程是程序的执行实例 线程是进程的执行路径 协程是基于线程之上但又比线程更加轻量级的存在 进程与线程的区别 线程是程序执行的最小单位,而进程是操作系统分配资源的最小单位 进程和程序的区别 程序:执行特定任务的一串代码&a…

牛客Linux高并发服务器开发学习第二天

Gcc编译 利用gcc 生成应用时如果不加-o 和应用名,默认生成a.out 可以用./ a.out打开 Gcc工作流程 可执行程序Windows系统中为.exe Linux系统中为.out g也可以编辑c程序 gcc也可以编译cpp代码,只是在编译阶段gcc不能自动共和C程序使用的库进行联接&…

JS-43-Node.js02-安装Node.js和npm

Node.js是一个基于Chrome V8引擎的JavaScript运行时环境,可以让JavaScript实现后端开发,所以,首先在本机安装Node.js环境。 一、安装Node.js 官网:下载 Node.js 默认两个版本的下载: 64位windows系统的LTS(Long Tim…

CST电磁仿真物体表面的Sheet结构和生成3D Model【基础教程】

由Sheet结构生成3D Model 使用Shell Solid and Thicken Sheet! Modeling > Tools > Shape Tools > Shell Solid or Thicken Sheet Shell Solidor ThickenSheet会根据不同类型的模型提供两种完全不同的功能。 如033.由3D Model生成Cavity 所述&#xff…

飞行机器人专栏(十四)-- Kinect DK 人体骨骼点运动提取方法

系列文章目录 Ubuntu 18.04/20.04 CV环境配置(下)--手势识别TRTposeKinect DK人体骨骼识别_ubuntu kinect骨骼测试-CSDN博客文章浏览阅读1.3k次。trt_pose_ros kinect实现手势识别和人体骨骼识别,用于机器人运动控制参考_ubuntu kinect骨骼测…

Postgresql源码(126)TupleStore使用场景与原理分析

相关 《Postgresql源码(125)游标恢复执行的原理分析》 《Postgresql游标使用介绍(cursor)》 总结 开源PG中使用tuple store来缓存tuple集,默认使用work_mem空间存放,超过可以落盘。在PL的returns setof场景…

Pascal VOC(VOC 2012、VOC 2007) 数据集的简介

一、数据集介绍 PascalVOC(2005~2012)数据集是PASCAL VOC挑战官方使用的数据集。该数据集包含20类的物体。每张图片都有标注,标注的物体包括人、动物(如猫、狗、岛等)、交通工具(如车、船飞机等)、家具(如椅…

Redux极客园项目初始化搭建

基本结构搭建 实现步骤 在 Login/index.js 中创建登录页面基本结构在 Login 目录中创建 index.scss 文件,指定组件样式将 logo.png 和 login.png 拷贝到 assets 目录中 代码实现 pages/Login/index.js import ./index.scss import { Card, Form, Input, Button }…

【LLM】认识LLM

文章目录 1.LLM1.1 LLM简介1.2 LLM发展1.3 市面常见的LLM1.4 LLM涌现的能力 2.RAG2.1 RAG简介2.2 RAG 的工作流程2.3 RAG 和 Finetune 对比2.4 RAG的使用场景分析 3. LangChain3.1 LangChain简介3.2 LangChain的核心组件3.3 LangChain 入门 4.开发 RAG 应用的整体流程5. 环境配…

GPT状态和原理 - 解密OpenAI模型训练

目录 1 如何训练 GPT 助手 1.1 第一阶段 Pretraining 预训练 1.2 第二阶段:Supervised Finetuning有监督微调 1.3 第三阶段 Reward Modeling 奖励建模 1.4 第四阶段 Reinforcement Learning 强化学习 1.5 总结 2 第二部分:如何有效的应用在您的应…