Jmeter 性能测试 —— 评估一个系统TPS与并发数!

news2025/2/6 6:04:34

问题:性能压测,如何评估一个系统的TPS和并发数?

1、对于新系统

由业务部门或开发人员预估交易量和TPS指标

可以参考公式:并发用户 = 在线用户数 * 10%。

当一个系统还没有上线时,我们可以预判的是这个系统准备要给多少人使用

如日常在线用户数量要支撑1000,那么并发用户参考值为:1000* 10%=100。

如果规定该业务的平均响应时间不高于500毫秒,那么通过TPS=并发用户数/业务平均时间

就可以得到TPS=100/0.5s=200笔/秒。

为了系统健壮性考虑,我们还可以在预估计算得到的TPS基础上扩个1.5倍得到200笔/秒* 1.5=300笔/秒。

即可得到该系统的TPS为300笔/秒,并发数为150。

2、对于已上线系统

TPS有两个公式:

公式一:TPS = 总请求 / 总时间,实际会考虑二八原则公式二:TPS = 并发数 / 业务平均时间

TPS一般有以下几种衡量系统性能指标的方式:

①一般业务系统,选取一天业务量,根据二八原则估算TPS指标

二八原则即:80%的业务在20%的时间里完成,TPS=(业务量 * 80%)/(时间(单位s) * 20%)

②秒杀类系统模型,选取高峰时间段业务量,估算TPS指标。

③波动类、交易集中类系统模型,选取特殊交易时间段业务量,预估TPS指标。

另外需要注意:TPS指标需要考虑业务增长量相关因素

如某银行系统某业务订单数据如下:

日常8小时,100万笔交易量,高峰期间交易量8万笔,高峰持续时间9分钟,预估系统3年内每年业务增长率为20%

那么:

该业务系统日常期间TPS为:TPS=(日常交易量 * 80%)/(时间 * 20%)=(100万 * 80%)/(8小时* 60 * 60 * 20%)≈139笔/秒
该业务系统高峰期间TPS为:TPS=高峰期间交易量/高峰持续时间(单位s)=8万/9分钟* 60≈148笔/秒
该业务系统包含每年业务增长率TPS为:首先三年后业务量=日常交易量* (1+20%)* (1+20%)* (1+20%)=100万* 1.2* 1.2* 1.2=172.8万
其次被测业务交易占总业务交易比例为:40%,那么被测试业务交易量为:总业务交易量* 40%=172.8万* 40%=69.12万
最后被测业务包含每年业务增长率TPS为:(被测试业务交易量* 80%)/(时间(单位s) * 20%)=(69.12万* 80%)/8小时* 60 * 60 * 20%)=96笔/秒
一般情况下,为了系统健壮性考虑,我们会在预估计算得到的未来的TPS基础上扩个1.5倍即:该业务系统包含每年业务增长率TPS为=96*1.5倍=144笔/秒。
该系统性能测试最低支持的并发数为:如果规定该业务的平均响应时间不高于500毫秒,那么通过TPS=并发用户数/业务平均时间,就可以得到并发用户数=0.5秒*144笔/秒=72个,即系统最低要求支持的并发数为:72个
说明:这里平均响应时间不同的公司不同业务可接受的响应时间是不同的
一般对于在线实时交易:互联网企业:500毫秒以下,例如淘宝业务10毫秒左右金融企业:1秒以下为佳,部分复杂业务3秒以下保险企业:3秒以下为佳制造业:5秒以下就行。
即可得到该系统的TPS为144笔/秒,并发数为72个。
现在我也找了很多测试的朋友,做了一个分享技术的交流群,共享了很多我们收集的技术文档和视频教程。
如果你不想再体验自学时找不到资源,没人解答问题,坚持几天便放弃的感受
可以加入我们一起交流。而且还有很多在自动化,性能,安全,测试开发等等方面有一定建树的技术大牛
分享他们的经验,还会分享很多直播讲座和技术沙龙
可以免费学习!划重点!开源的!!!
qq群号:691998057【暗号:csdn999】

3、横向TPS扩展

假设单节点我们通过上面的方法,计算出来的TPS为150笔/秒,平均响应时间不高于500毫秒,并发用户数75个

现在我们想要系统支撑高并发数,通过扩展服务器数量来提升业务处理的能力。

那么,我们也可以计算横向TPS扩展增长率:

单节点TPS:150笔/秒2节点TPS:265笔/秒,则增长率为:(2节点TPS-单节点TPS)/(2节点-1)/单节点TPS=(265-150)/(2-1)/150≈76.67%3节点TPS:375笔/秒,则增长率为:(3节点TPS-单节点TPS)/(3节点-1)/单节点TPS=(375-150)/(3-1)/150≈75%4节点TPS:488笔/秒,则增长率为:(4节点TPS-单节点TPS)/(4节点-1)/单节点TPS=(488-150)/(4-1)/150≈75.11%5节点TPS:600笔/秒,则增长率为:(5节点TPS-单节点TPS)/(5节点-1)/单节点TPS=(600-150)/(5-1)/150≈75%6节点TPS:715笔/秒,则增长率为:(6节点TPS-单节点TPS)/(6节点-1)/单节点TPS=(715-150)/(6-1)/150≈75.33%7节点TPS:825笔/秒,则增长率为:(7节点TPS-单节点TPS)/(7节点-1)/单节点TPS=(825-150)/(7-1)/150≈75%8节点TPS:940笔/秒,则增长率为:(8节点TPS-单节点TPS)/(8节点-1)/单节点TPS=(940-150)/(8-1)/150≈75.24%9节点TPS:1050笔/秒,则增长率为:(9节点TPS-单节点TPS)/(9节点-1)/单节点TPS=(1050-150)/(9-1)/150≈75%10节点TPS:1165笔/秒,则增长率为:(10节点TPS-单节点TPS)/(10节点-1)/单节点TPS=(1165-150)/(10-1)/150≈75.19%

一般情况下,我们要求扩展服务器的数量进行高并发的处理,TPS增长率应在75%以上。

END今天的分享就到此结束了!点赞关注不迷路!

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

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

相关文章

12.25

led.c #include "led.h" void all_led_init() {RCC_GPIO | (0X3<<4);//时钟使能GPIOE_MODER &(~(0X3<<20));//设置PE10输出GPIOE_MODER | (0X1<<20);//设置PE10为推挽输出GPIOE_OTYPER &(~(0x1<<10));//PE10为低速输出GPIOE_OSPEED…

关于“Python”的核心知识点整理大全43

目录 ​编辑 15.2.3 使2散点图并设置其样式 scatter_squares.py 15.2.4 使用 scatter()绘制一系列点 scatter_squares.py 15.2.5 自动计算数据 scatter_squares.py 15.2.6 删除数据点的轮廓 15.2.7 自定义颜色 15.2.8 使用颜色映射 scatter_squares.py 注意 15.2.9…

C# Winform教程(二):基础窗口程序

1、介绍 winform应用程序是一种智能客户端技术&#xff0c;我们可以使用winform应用程序帮助我们获得信息或者传输信息等。 2、常用属性 Name&#xff1a;在后台要获得前台的控件对象&#xff0c;需要使用Name属性。 Visible&#xff1a;指示一个控件是否可见、 Enable&…

超声系统前端理论与模拟仿真-续

作者&#xff1a;蒋志强 本人同意他人对我的文章引用&#xff0c;但请在引用时注明出处&#xff0c;谢谢&#xff0e;作者&#xff1a;蒋志强 前言 近期整理了一下彩超前端及波束合成相关的内容&#xff0c;很早以前已经有过一次&#xff0c;这次把其它的内容总结一下&#xf…

前端canvas项目实战——简历制作网站(一)——左侧工具栏

目录 前言一、效果展示二、实现步骤1. 拆分旧代码&#xff0c;优化项目结构2. 左侧工具栏3. 组合代码 三、Show u the code后记 前言 在fabric基础系列博文中&#xff0c;我们通过代码向画布canvas中添加矩形、圆形等对象。对于用户&#xff0c;我们不能指望他们可以理解代码&…

改变命运第一法

不与事争&#xff0c;你争不过因果&#xff1b;不与人争&#xff0c;会伤了感情&#xff1b;不与己争&#xff0c;会让人心累。平静淡泊、守望平和&#xff0c;不指责&#xff0c;不抱怨&#xff0c;不计较&#xff0c;永远做个善良清澈的自己&#xff0c;以善为本&#xff0c;…

Linux OpenEuler(欧拉系统)无公网ip实现SSH远程连接

&#x1f525;博客主页&#xff1a; 小羊失眠啦. &#x1f3a5;系列专栏&#xff1a;《C语言》 《数据结构》 《Linux》《Cpolar》 ❤️感谢大家点赞&#x1f44d;收藏⭐评论✍️ 前些天发现了一个巨牛的人工智能学习网站&#xff0c;通俗易懂&#xff0c;风趣幽默&#xff0c;…

【MySQL】一文看懂MySQL所有常见问题

MySQL作为一款开源关系型数据库&#xff0c;如今绝对是占据关系型数据库的主导地位&#xff0c;不仅是面试中的常客&#xff0c;也是日常工作中最主要接触的数据库。因此&#xff0c;无论是背面试八股&#xff0c;还是工作使用&#xff0c;都是一定要深度掌握的一个知识点。今天…

云上安全责任共担模型

对于传统自建物理服务器模式&#xff0c;用户需要承担所有的安全责任&#xff0c;负责从物理基础设施到上层应用的所有层面的安全体系构建。 云服务器的安全责任确实与物理服务器不同&#xff0c;云上的安全性是一种责任共担模式&#xff0c;其中云服务器ECS的安全责任需要你&…

算法通关村第十关—归并排序(黄金)

归并排序 一、归并排序原理 归并排序(MERGE-SORT)简单来说就是将大的序列先视为若干个比较小的数组&#xff0c;分成几个比较小的结构&#xff0c;然后是利用归并的思想实现的排序方法&#xff0c;该算法采用经典的分治策略&#xff08;分就是将问题分(divide)成一些小的问题分…

阶段性复习(二)

阶段性复习第二弹&#xff01; 一.操作符 继上期复习了一部分&#xff0c;我们继续复习操作符&#xff0c;今天着重复习双目操作符 有一类题&#xff0c;通过结果分析反推求过程中的表达式 从这道题可以看出&#xff0c;t是4的时候&#xff0c;s要是2&#xff0c;所以a&…

飞天使-k8s知识点7-kubernetes升级

文章目录 验证新版本有没有问题需要安装的版本微微 1.20.6.0kubeadm upgrade plan 验证新版本有没有问题 查看可用版本的包 现有的状态 查看版本 yum list kubeadm --showduplicates |grep 1.20 yum list kubelet --showduplicates |grep 1.20 yum list kubectl --showduplic…

云渲染UE4像素流送搭建(winows、ubuntu单实例与多实例像素流送)

windows/ubuntu20.4下UE4.27.2像素流送 像素流送技术可以将服务器端打包的虚幻引擎应用程序在客户端的浏览器上运行&#xff0c;用户可以通过浏览器操作虚幻引擎应用程序&#xff0c;客户端无需下载虚幻引擎&#xff0c;本文实现两台机器通过物理介质网线实现虚幻引擎应用程序…

推荐3款高效又免费的MP4转MP3格式转换工具

在日常生活和工作中&#xff0c;我们经常会遇到需要将MP4视频文件转换成MP3音频文件的情况&#xff0c;以便在其他设备上播放或享受音频内容。如果你正在寻找一款高效又免费的MP4转MP3格式转换工具&#xff0c;那么你来对地方了&#xff01;本文将为你推荐3款最佳工具&#xff…

STM32使用printf重定向到USART

配置你想要重映射的串口&#xff0c;这里用串口1举例子&#xff0c;你完全可以定义成其他串口。 波特率和位数格式完全按照需要定义&#xff0c;这里不要开启dma和中断。 这里建议使用单独生成.c和.h&#xff0c;当然你不生成也完全可以。 /* USER CODE BEGIN 0 */ int __io_p…

重装系统后桌面图标没有了,“此电脑”怎么添加?

重装电脑系统对于使用电脑的用户来说是一种很常见的操作。但是有时在重装系统之后&#xff0c;我们会发现电脑桌面图标不见了&#xff0c;那么这时该怎么办呢&#xff1f;“此电脑”该怎么添加呢&#xff1f; 解决方法&#xff1a; 1.在桌面空白处单击鼠标右键&#xff0c;选择…

九州金榜|家庭教育中注意孩子早起抑郁症征兆

在现代社会&#xff0c;心理健康问题越来越受到关注和重视。尤其是青少年&#xff0c;由于学业、人际关系等因素&#xff0c;可能会面临抑郁症的困扰。然而&#xff0c;很多家长对孩子的心理状况缺乏了解&#xff0c;未能及时发现他们心中的烦恼。以下是一些关于抑郁症早期征兆…

anaconda prompt进入虚拟环境 打开spyder

目录 1.查看有多少虚拟环境 2.conda create 指令创建新的虚拟环境 3.进入虚拟环境 4.spyder进入虚拟环境 5.退出虚拟环境 6.删除虚拟环境 1.查看有多少虚拟环境 打开anaconda prompt&#xff0c;输入 conda env list 2.conda create 指令创建新的虚拟环境 conda cre…

免费高清无水印视频素材在哪里下?

剪辑是一门创意工作&#xff0c;但很多初学者常常感到困惑&#xff0c;原因并不是因为他们不懂剪辑&#xff0c;而是因为他们不知道从哪里找到合适的素材。今天&#xff0c;我们将为大家盘点一些超全的剪辑素材资源&#xff0c;包括视频素材、音乐素材和图片素材等&#xff0c;…

Vue axios 拦截器

正常情况下打开浏览器前端页面向后端发起请求使用的是axios&#xff0c;无论是原生的axios还是自己封装的axios都看成是axios。发起请求之后后端去数据库里面拿数据&#xff0c;然后返回给前端。 发起请求的地方是axios&#xff0c;并且你能够封装这个axios&#xff0c;那么你…