01
主要术语
用户数
有时会看到下面这样的描述:一个系统注册用户达到6000万人,其中每小时的活跃用户大概在60万人左右。这段描述介绍了两个信息,第一个信息:6000万人指的是注册用户,第二个信息:60万人指的是真实在线用户。
- 注册用户数 (系统用户数)
注册用户是 存在于系统数据库表中的基础数据。这部分用户是指系统所拥有的所有用户群体。这些用户是不会全部对系统造成压力的,唯一的压力就是这些用户占用了系统的存储,影响了数据库的容量。
- 在线用户
在线用户是 真实产生压力的用户,这些用户是压力的根源,也就是系统要能够支持这么多人同时在线业务。
同时在线用户数:在一定的时间范围内,最大的同时在线用户数量
同时在线用户数 = 每秒请求数RPS(吞吐量)+并发连接数+平均用户思考时间
- 并发用户
在线用户是真实的用户,但不是所有的在线用户都会在系统上操作,可能有些用户在浏览网页、有些用户在做业务、有些用户只是开着浏览器。这时在线用户对系统产生压力的用户只有一部分,而这部分用户就是在线用户中的有效并发用户
平均并发用户数的计算: C=nL / T 其中 C是平均的并发用户数, n是平均每天访问用户数(login session), L是一天内用户从登录到退出的平均时间(login session的平均时间), T是考察 时间长度(一天内多长时间有用户使用系统) 并发用户数峰值计算: C^约等于C + 3*根号C 其中 C^是并发用户峰值, C是平均并发用户数,该公式遵循泊松分布理论 |
对绝大多数场景,我们用 (用户总量/统计时间)*影响因子(一般为3)来进行估算并发量
- 虚拟用户
虚拟用户即 Virtual User,简称Vuser,是性能测试工具产生的用户,用来 模拟真实用户进行的一系列业务逻辑操作
事务(TPS)
- 事务 :事务指的是业务逻辑上的事务 例 : 注册用户是一个事务,只用胡提交注册发生时到注册成功返回页面时的事务,它包括多个页面或者JS等组件的交互
- TPS :每秒钟事务数量
- 事务并发数 :系统同时处理的事务数
- 响应时间 :一般的相应时间都是指事务从开始到结束时间;取平均响应时间
理解了上面三个要素的意义之后,就能推算出它们之间的关系:
TPS= 事务并发数/平均响应时间
事务并发数= TPS*平均响应时间
无论有无思考时间(TS),测试所得的TPS值和并发虚拟用户数(Vu)、交易响应时间(T)之间有以下关系(稳定运行情况下):
TPS=Vu / (T+TS)
响应时间
对请求作出响应所需要的时间:
- 网络传输时间 :N1(发送请求)+N2(内部处理请求)+N3(返回结果)+N4(展示结果)
- 应用服务器处理时间 :A1(处理请求)+A3(返回结果)
- 数据库服务器处理时间 :A2(操作数据库时间)
响应时间= N1+N2+N3+N4+A1+A3+A2
在性能测试结果分析中,分为事务最小响应时间、事务平均响应时间、事务最大响应时间和90%事务响应时间。一般时间的 标准时间为90%响应时间,即测试过程中90%的业务用了多长时间。
QPS
在性能测试中有时可以将TPS、QPS认为是一样的:
- QPS :每秒钟request数量(每秒查询率),是对一个查询服务器在规定时间内所处理流量多少的衡量标准
- 请求并发数 :系统同时处理的request数
- 响应时间 :一般取平均响应时间
理解了上面三个要素的意义之后,就能推算出它们之间的关系:
QPS = 请求并发数/平均响应时间
请求并发数= QPS*平均响应时间
一个典型的上班签到系统,早上8点上班,7点半到8点的30分钟的时间里用户会登录签到系统进行签到。公司员工为1000人,平均每个员上登录签到系统的时长为5分钟,可以用下面的方法计算:
QPS= 1000/(30*60) 事务/秒
平均响应时间= 5*60 秒
并发数= QPS平均响应时间 = 1000/(3060) (560)=166.7
PV(Page View)
PV即Page View,意思是页面浏览量或单机率,通常是 用来衡量一个网站的主要指标
一个PV狭义上讲等于一个TPS,可以将页面元素从性能测试结果中分析出来,所以也可以将PV和TPS整合;但是广义上来说,一个页面有很多的图片、链接和CSS等,而这里的每一个图片、链接都是PV
思考时间
Think Time,从业务角度来看,这个时间指用户进行操作时每个请求之间的时间间隔,而在做新能测试时,为了模拟这样的时间间隔,引入了思考时间这个概念,来 更加真实的模拟用户的操作。
- 在吞吐量这个公式中 F=Vu * R / T 说明吞吐量F是Vu数量、每个用户发出的请求数R和时间T的函数,而其中的R又可以用时间T和用户思考时间TS来计算: R = T / TS
下面给出一个计算思考时间的一般步骤:
A、 首先计算出系统的并发用户数
C= nL / T F= R×C
B、 统计出系统平均的吞吐量
F= VU * R / T R×C = VU * R / T
C、 统计出平均每个用户发出的请求数量
R= u*C*T/VU
D、 根据公式计算出思考时间
TS= T/R
吞吐量(一般指字节)
吞吐量是一次性能测试过程中网络上传输的数据量的总和,也可以这样说在单次业务中,客户端与服务器端进行的数据交互总量;
- 对于交互式应用来说, 吞吐量指标反映的是服务器承受的压力 ,他能够说明系统的负载能力
- 一个系统吞吐量通常由 QPS(TPS) 、 并发数 两个因素决定,每套系统这两个值都 有一个相对极限值 ,在应用场景访问压力下,只要某一项达到系统最高值,系统的吞吐量就上不去了,如果压力继续增大,系统的吞吐量反而会下降,原因是系统超负荷工作,上下文切换、内存等等其它消耗导致系统性能下降。
吞吐率(一般指字节)
吞吐率作为一个重要的衡量指标,最主要应用在 并行处理上 ,属于系统结构中最重要的一个变量,它的定义是:单位时间的吞吐量。
- 吞吐率在性能测试中指单位时间内在网络上传输的数据量。是 衡量网络性能的主要指标。
- 从网络角度看,吞吐率可以用: 字节/秒 来衡量
- 从业务角度看,吞吐率可以用: 请求数/秒 、 页面数/秒 、 人数/天 或 处理业务数/小时 等单位来衡量
- 以不同方式表达的吞吐率可以说明不同层次的问题。
例如,以字节数/秒方式可以表示数要受网络基础设施、服务器架构、应用服务器制约等方面的瓶颈;已请求数/秒的方式表示主要是受应用服务器和应用代码的制约体现出的瓶颈。
- (请求数)当没有遇到性能瓶颈的时候,吞吐量与虚拟用户数之间存在一定的联系,可以采用以下公式计算: F=Vu * R /T 其中 F :吞吐率, Vu :虚拟用户个数, R :每个虚拟用户发出的请求数, T :性能测试所用的时间
性能计数器
是描述服务器或操作系统性能的一些数据指标,如使用内存数、进程时间,在性能测试中发挥着“ 监控和分析”的作用,尤其是在分析统统可扩展性、进行新能瓶颈定位时有着非常关键的作用。
- 资源利用率: 指系统各种资源的使用情况,如cpu占用率为68%,内存占用率为55%,一般使用“ 资源实际使用/总的资源可用量 ”形成资源利用率。
02
几个非主要术语
集合点
- 插入集合点是 为了衡量加重负载情况下的性能情况
- 在计划中,可能会要求系统承受1000人同时提交数据,在提交数据操作前加入集合点,当虚拟用户运行到提交数据的集合点时,会自动检查同时有多少用户运行到集合点,当达到指定用户数时,将命令指定用户数同时提交数据,从而达到同时提交的要求
- 集合点是相对的 ,因为没有绝对的并发,集合点只是尽可能的在同一时间发送请求,但是服务器是没办法在同一秒接受并处理请求的
迭代
迭代是重复执行过程,性能测试中就是一个事务流程重复执行的过程。通过调整每次迭代的时间,就能控制整个事务流程完成的时间,进而控制TPS的大小
步调
步调是指两次迭代之间的间隔时间,可以通过设置步调来调整各个Action之间的执行等待时间。从定义上看,步调和迭代是绑定在一起的,可以认为是 Iteraction Pacing
每秒连接数
每秒连接数实现Web应用程序在运行过程中每秒建立的HTTP连接数。理想情况下,很多HTTP请求都应该使用同一个连接也就是长连接,而不是每个请求都新打开一个连接。如果程序中不断的打开长连接或者频繁的创建达到上千个短连接,那么应用服务器的相应会越来越慢。通过 每秒连接数可以看出服务器的处理情况。
学习安排上!
码个资料送给你
▲ 《2022大厂最新面试题》▲
关注下方公众号免费领取
不想错过就把我们设为星标吧!
“自动化软件测试”,进入公众号主页
第二步:点击右上角 “···”
第三步:点击 “设为星标”
上文内容不用于商业目的,如涉及知识产权问题,请权利人后台留言联系码同学小编,我们将立即处理。
转载自:http://navo.top/JjqeAr
“在看”点一点
春天的温柔,长满了枝头??
?? ?? ??
来源:思修考试法宝
声明:本站部分文章及图片源自用户投稿,如本站任何资料有侵权请您尽早请联系jinwei@zod.com.cn进行处理,非常感谢!