基于目标TPS的性能测试,如何通过手动设置场景进行测试?

开发 测试
本文介绍了基于目标tps的性能测试方法,希望通过本文,能让大家对tps的设置有更深入的了解,在做性能测试时做到目标清晰,有章可循。

一、性能测试中的TPS

众所周知,TPS(即Transactions Per Second的缩写)是性能测试中的一项重要指标,用于衡量被测系统的性能,TPS高则说明系统处理速度快,TPS低则说明系统处理速度慢,可能需要做性能优化。通常TPS只是反应测试结果,测试出多少就是多少,然而很多时候我们需要事先指定TPS的目标值,通过测试来验证目标值是否达,那么该如何进行测试呢?

二、基于目标的性能测试

Loadrunner在新建测试场景时,就可以选择手动场景还是基于目标的场景,如下图所示:

目标类型可以选择tps、hits per second等:

设置好目标后,直接运行就可以了,执行完成可以看到目标是否达到了。这个过程都是自动完成的,其内部是如何实现的,对于我们来说完全是个黑盒子。本文介绍的是如何通过手动设置场景来完成基于TPS目标的测试,重点介绍目标TPS是如何计算出来的。

三、测试场景的设置

我们还是选择手动设置loadrunner的测试场景,通常会有单交易场景测试和混合交易场景测试,下面是2个示例:

无论是单场景还是混合场景,目标TPS的计算原理都是一样的。

四、场景公式

在上面的场景例子中,我们需要重点关注4个字段:

  • 虚拟用户数量(简称vu)
  • 目标tps
  • Pacing
  • Thinktime

所有场景的 thinktime 都是 0 秒,pacing 和 thinktime 在概念上有联系也有区别。

Thinktime 比较常用,易理解,这里不多介绍,下面重点说一下 pacing。Pacing 是 loadrunner中的一个设置选项,如下图所示:

Pacing 指 action 迭代的延迟时间,选项一是迭代不延迟,选项二是在上一次迭代结束后多长时间开始下一次迭代,选项三是每次迭代从开始到结束的时间间隔。

选项三实际上是设置每次迭代的期望完成时间,例如设置pacing为60秒,表示action这个事务要求在60秒内执行完成,如果action执行了4秒,那么后面的56秒会等待,直到60秒后再开始下一次迭代;如果action执行了120秒,那么执行结束后会立即开始下一次迭代。前者我们可以称之为“包含住”,因为执行时间小于pacing时间,后者称为“未包含住”,因为执行时间大于pacing时间。只要action的平均响应时间“包含住”了,目标TPS就可以达到。

理解上面的原理很重要,下面我们看一个例子。

假设有如下的测试结果:

vu为1时action的响应时间只要小于等于2秒pacing,理论tps应该都是0.5,换句话说只要action响应时间在pacing内,响应时间再快,tps不会增加。

vu为 10 时,action的响应时间仍小于2秒,在pacing范围内,“包含住”了,达到5个TPS。同理,vu为20时,action的响应时间仍小于2秒,在pacing范围内,“包含住”了,达到10 个TPS。在action的响应时间未超出pacing之前,tps和vu存在正比关系。

vu为100时,action响应时间为10秒,不在pacing2秒范围内,“未包含住”,理论的50个tps就不可能达到了。

通过以上分析,我们可以得出vu、pacing、目标tps三者之间的关系,即:

在action的响应时间未超出pacing之前,目标tps=vu/pacing通过该公式,可以较精确的测试出系统的tps,通过大量的测试试验,结果也是和公式吻合的。

目标tps根据需求得到,设置一个pacing就知道需要测试多少vu。减少pacing和增加vu都可以增加目标tps。建议的做法是先设定pacing,然后再设置vu,pacing的取值基本都是10秒,或者是10秒的倍数。pacing确定后就不再改变,要想增加目标tps,只能调大vu。

五、总结

本文介绍了基于目标tps的性能测试方法,希望通过本文,能让大家对tps的设置有更深入的了解,在做性能测试时做到目标清晰,有章可循。

责任编辑:赵宁宁 来源: 今日头条
相关推荐

2011-07-04 17:38:47

性能测试

2021-07-03 08:54:49

LinuxSysbench性能

2018-08-02 17:11:33

iOS 12苹果bug

2019-07-24 09:00:00

New Relic性能工程压力测试

2013-10-15 10:11:33

产品测试使用场景产品

2015-03-19 09:35:36

OpenStack平台性能测试Rally功能测试Tempest

2012-03-26 10:55:03

JavaJava EE

2023-08-31 08:36:52

.NET性能测试开源

2023-09-28 21:55:12

AndroidApp

2023-12-06 09:33:54

Reactor网络

2021-12-16 08:00:00

推荐系统MovieMat数据

2022-06-22 09:41:16

接口异常测试

2016-09-23 16:36:25

LinuxPCPhoronix

2021-12-29 10:30:15

JMH代码Java

2012-12-18 13:32:45

IBMdW

2023-09-03 23:49:35

2023-03-24 16:18:08

微服务架构

2020-05-18 07:00:00

性能测试压力测试负载测试

2011-06-08 16:59:04

性能测试载测试压力测试

2013-06-27 10:34:08

准备性能测试数据
点赞
收藏

51CTO技术栈公众号