[b]1. 背景[/b]
在做性能测试的时候,很多人都用并发用户数来衡量系统的性能,觉得系统能支撑的并发用户数越多,系统的性能就越好;对TPS不是非常理解,也根本不知道它们之间的关系,因此非常有必要进行解释。
[b]2. 术语定义[/b]
Ø 并发用户数:指的是现实系统中操作业务的用户,在性能测试工具中,一般称为虚拟用户数(Virutal User),注意并发用户数跟注册用户数、在线用户数有很大差别的,并发用户数一定会对服务器产生压力的,而在线用户数只是 ”挂” 在系统上,对服务器不产生压力,注册用户数一般指的是数据库中存在的用户数。是指服务器同时处理用户请求的数量(可视为连接数)
Ø TPS:Transaction Per Second, 每秒事务数, 是衡量系统性能的一个非常重要的指标。
Ø QPS:Queries Per Second, 查询量/秒,是一台服务器每秒能够响应的查询次数,是对一个特定的查询服务器在规定时间内所处理查询量多少的衡量标准。
需要注意的是:连上了,并不等于就能进行处理了。动态网站大多有数据库支撑,而数据库也有个并发数
[b]3. Vu和TPS换算[/b]
Ø 简单例子:在术语中解释了TPS是每秒事务数,但是事务时要靠虚拟用户做出来的,假如1个虚拟用户在1秒内完成1笔事务,那么TPS明显就是1;如果某笔业务响应时间是1ms,那么1个用户在1秒内能完成1000笔事务,TPS就是1000了;如果某笔业务响应时间是1s,那么1个用户在1秒内只能完成1笔事务,要想达到1000TPS,至少需要1000个用户;因此可以说1个用户可以产生1000TPS,1000个用户也可以产生1000TPS,无非是看响应时间快慢。
Ø 复杂公式:
试想一下复杂场景,多个脚本,每个脚本里面定义了多个事务(例如一个脚本里面有100个请求,我们把这100个连续请求叫做Action,只有第10个请求,第20个请求分别定义了事务10和事务20)具体公式如下:
符号代表意义:
Vui表示的是第i个脚本使用的并发用户数
Rtj表示的是第i个脚本第j个事务花费的时间,此时间会影响整个Action时间
Rti表示的是第i个脚本一次完成所有操作的时间,即Action时间
n 表示的是第n个脚本
m 表示的是每个脚本中m个事务
那么第j个事务的TPS = Vui/Rti
总的TPS=
[b]4. 如何获取Vu和TPS[/b]
Ø 并发用户数(Vu)获取
新系统:没有历史数据作参考,只能通过业务部门进行评估。
旧系统:对于已经上线的系统,可以选取高峰时刻,在一定时间内使用系统的人数,这些人数认为属于在线用户数,并发用户数取10%就可以了,例如在半个小时内,使用系统的用户数为10000,那么取10%作为并发用户数基本就够了。
Ø TPS获取
新系统:没有历史数据作参考,只能通过业务部门进行评估。
旧系统:对于已经上线的系统,可以选取高峰时刻,在5分钟或10分钟内,获取系统每笔交易的业务量和总业务量,按照单位时间内完成的笔数计算出TPS,即业务笔数/单位时间(5*60或10*60)
[b]5. 如何评价系统的性能[/b]
针对服务器端的性能,以TPS为主来衡量系统的性能,并发用户数为辅来衡量系统的性能,如果必须要用并发用户数来衡量的话,需要一个前提,那就是交易在多长时间内完成,因为在系统负载不高的情况下,将思考时间(思考时间的值等于交易响应时间)加到脚本中,并发用户数基本可以增加一倍,因此用并发用户数来衡量系统的性能没太大的意义。
[b]6. 相关案例[/b]
通过大量性能测试我们发现不需要用上万的用户并发去进行测试,只要系统处理业务时间足够快,几百个用户甚至几十个用户就可以达到目的。另外咨询很多专家做过的性能测试项目,基本都没有超过5000用户并发。
因此对于大型系统、业务量非常高、硬件配置足够多的情况下,5000用户并发就足够了;对于中小型系统,1000用户并发就足够了。
[b]7. 性能测试策略[/b]
做性能测试需要一套 标准化流程及测试策略,并发用户数只是指标考虑的一个,在做负载测试的时候,一般都是按照梯度施压的方式去加用户数,而不是在没有预估的情况下,一次加几 万个用户,,交易失败率非常高,响应时间非常长,已经超过了使用者忍受范围内,这样做没有多大的意义,这就好比“有多少钱可以干多少事”一样,需要选择相 关的策略。
[b]8. 总结[/b]
Ø 系统的性能由TPS决定,跟并发用户数没有多大关系。在同样的TPS下,可以由不同的用户数去压(通过加思考时间设置)。
原文出处:《并发用户数与TPS之间的关系》
Ø 系统的最大TPS是一定的(在一个范围内),但并发用户数不一定,可以调整。
Ø 建议性能测试的时候,不要设置过长的思考时间,以最坏的情况下对服务器施压。
Ø 一般情况下,大型系统(业务量大、机器多)做压力测试,5000个用户并发就够了,中小型系统做压力测试,1000个用户并发就足够了。
分享到:
相关推荐
本文将详细解释TPS在线用户和并发的关系,包括在线用户数和压力线程之间的关系、并发用户数的计算、并发度的计算等。 在线用户数和压力线程之间的关系 在线用户数是指系统中当前活动的用户数量,而压力线程是指...
性能之并发用户数的计算 标题解释 ...7. 并发用户数和 TPS 都是评估系统性能的重要指标,但是在评定服务器的性能时,应该结合 TPS 和并发用户数,以 TPS 为主,并发用户数为辅来衡量系统的性能。
在IT行业中,性能测试是评估系统能力的关键环节,其中几个重要的指标包括TPS(吞吐量)、QPS(每秒查询率)、并发数以及RT(响应时间)。理解这些概念有助于优化系统性能,提高用户体验。 1. 响应时间(Response Time, RT...
- 负载测试:在增加并发用户数时,如果TPS没有相应提升或反而下降,表明系统可能无法有效处理更多并发请求。 - 稳定性测试:通过观察TPS在长时间运行下的稳定性,可以评估系统的可持续工作能力。 7. **优化策略**...
系统吞吐量的三个关键参数是QPS(Queries Per Second,与TPS相似)、并发数和响应时间。QPS指的是每秒钟处理的请求数量。并发数代表系统同时处理的请求或事务数。响应时间通常指的是平均响应时间,即从发出请求到...
此外,系统吞吐量通常由两个重要因素决定:QPS(Queries Per Second,与TPS类似)和并发数。 QPS代表每秒请求数,它与系统的处理能力直接相关。并发数则是系统同时处理的请求或事务数量。响应时间,通常指平均响应...
在IT行业中,性能测试是衡量系统效率和稳定性的重要环节,其中关键的概念包括吞吐量(TPS)、每秒查询率(QPS)、并发数以及响应时间(RT)。这些指标是评估系统性能的基础,理解它们有助于优化系统设计和提升用户...
此外,TPS、并发数和响应时间之间存在如下关系:TPS=U_concurrent / (T_response+T_think),其中U_concurrent是并发虚拟用户数,T_response是交易响应时间,T_think是思考时间。 在软件性能测试中,关注的性能点...
当我们在调整线程数(即并发用户数)时,可以通过观察TPS的变化来确定最佳的并发水平。一般来说,增加线程数会提高TPS,但过高的线程数可能导致服务器资源耗尽,反而降低TPS,因此找到这个平衡点至关重要。 在进行...
常用的网站性能测试指标有:并发数、响应时间、吞吐量、性能计数器等。 1、并发数 并发数是指系统同时能处理的请求数量,这个也是反应了系统的负载能力。 2、响应时间 ...QPS(TPS),并发数、
在测试过程中,"tps"( Transactions Per Second,每秒事务数)是衡量系统性能的关键指标之一,它反映了系统处理请求的速度。本扩展插件正是针对JMeter的功能增强,目的是帮助测试人员更方便地生成和分析tps数据。 ...
- TPS(每秒交易数)是衡量系统处理能力的一个重要指标,尤其是在分布式系统和高并发场景下。 - 在Java应用中,TPS测试通常用于评估系统在单位时间内能够处理的事务数量,以确保系统的性能满足业务需求。 #### 2....
JMeter每秒事务数(Transactions Per Second, TPS)插件是JMeter性能测试中的一个重要工具,用于衡量系统在一定压力下的处理能力。这个插件是JMeter社区项目的一部分,由jmeter-plugins.org提供,其最新版本为jpgc-...
在IT行业中,尤其是在Java架构设计领域,理解和计算系统峰值、TPS(每秒事务数)、QPS(每秒查询率)以及并发数等指标对于优化系统性能至关重要。这些概念是评估系统负载能力和处理能力的标准。 1. **响应时间(RT...
- QPS (TPS) = 并发数 / 平均响应时间 - 这个公式揭示了系统吞吐量与并发数和响应时间之间的内在联系。简而言之,系统吞吐量取决于系统在同一时间能够处理多少请求,以及每个请求的平均处理时间。 #### 三、决定...
- C^ 是并发用户峰值,C 是平均并发用户数。 **3. 吞吐量** - 定义: 单位时间内系统处理的请求数。 - 计算公式: F = VU * R / T - 其中,F 为吞吐量,VU 表示虚拟用户个数,R 表示每个虚拟用户发出的请求数,T ...