常数吞吐量定时器(Constant Throughput Timer)通常用于控制吞吐量,您可以根据压测脚本的业务目的,来选择不同的计算模式。若叠加上分布式施压源,您需要考虑脚本中的配置值及配置模式,以便匹配不同的压测目标模型。本文将从应用场景的角度介绍2种常见的使用模式,以及分布式适配不同计算模式的效果。

通过以下示例您可以了解到不同的分布式适配方式。假设使用到2台施压IP,并发为100,脚本上仅1个线程组,其吞吐量目标为每分钟100,计算模式为当前线程(this thread only)。
  • 全局生效即为脚本中设置值为集群整体阈值,施压机会根据使用到的IP数来拆分到单机吞吐量目标值上(即单施压机阈值为脚本中值/IP数),此时场景的总目标吞吐量为2×(100并发/2 )×(100/2)=5000(每分钟)。
  • 单机生效即为脚本中设置值为单台施压机的目标值,不会替换脚本内容,需要注意并发量级与配置值是否匹配。该模式下,场景的总目标吞吐量为2×(100并发/2 )×100=10000(每分钟)。
  • 常见应用场景

    通常配置吞吐量控制时,您可以选择Sampler维度或线程组维度(多线程组即全场景维度)即可,不推荐使用其他过于复杂的场景。以下示例中使用了2台施压机IP,线程组总并发100,目标吞吐量每分钟100。

    Sampler吞吐量控制的实现

    登录 PTS控制台 ,在左侧导航栏选择 性能测试 > 创建场景 ,然后单击 JMeter压测

  • 选择 场景配置 页签,在 常数吞吐量定时器 中选择 单机生效
    说明 只有上传的脚本中设置了定时器, 场景配置 中才会出现 分布式适配设置 的配置框。
  • JMeter脚本中将该组件(Constant Throughput Timer)置于Sampler下面。
  • 设置 Target Throughput 100 ,单位为分钟。 计算模式 选择 this thread only ,如下图所示。 Sampler
  • 线程组吞吐量控制的实现

    登录 PTS控制台 ,在左侧导航栏选择 性能测试 > 创建场景 ,然后单击 JMeter压测

  • 选择 场景配置 页签,在 常数吞吐量定时器 中选择 全局生效
    说明 只有上传的脚本中设置了定时器, 场景配置 中才会出现 分布式适配设置 的配置框。
  • JMeter脚本中将该组件(Constant Throughput Timer)置于Sampler下面。
  • 设置 Target Throughput 100 ,单位为分钟。 计算模式 选择 All active threads in current thread group ,如下图所示。 线程组1
  • 5种计算模式

    示例:假设使用单台施压源,2个线程组,即分别含有2个Sampler,分别是100并发和200并发, Target Throughput 均是每分钟100。

    说明 以下示例仅供参考,具体请以官方文档为准,请参见 官方文档 。 非活跃的线程,没有对应的吞吐量,按照上述示例(每分钟):
  • 线程组1:每个线程每分钟发出请求100次,即Sampler1.1和Sampler1.2各自的吞吐量都是100线程×100次/60秒=83左右。
  • 线程组2:每个线程每分钟发出请求100次,即Sampler2.1和Sampler2.2各自的吞吐量都是200线程×100次/60秒=160左右。
  • 配置到Sampler上即可控制到单个Sampler的吞吐量。
  • All active threads 将设置的吞吐量,分配到活跃的线程上(所有线程组的所有线程),然后这个线程在上次运行自行结束之后,等待合理时间(为了控制吞吐量)再次运行。 多线程组的时候,要求其他线程组也有一样的配置按照上述示例:
  • 因为线程是一开始就发出去,所以在执行第二个Sampler的时候,吞吐量就会非常低。因为是从线程组维度控制的,每个线程吞吐量分别是每分钟为1和2,所以到第二个Sampler的时候,次数会减少。
  • 线程组的Throughput是每分钟为100,全局的吞吐量是每分钟为200。
  • 需要运行一段时间之后(线程组内多个Sampler发出去的请求数一致=并发数),每个线程组内Sampler的吞吐量才会趋于均衡。
  • All active threads in current thread group 将设置的吞吐量,分配到活跃的线程上(当前线程组的活跃线程),然后这个线程在上次运行自行结束之后,等待合理时间(为了控制吞吐量)再次运行。 单线程组的时候,与上一个相同。按照上述示例:
  • 因两个Timer的配置一致,故和上述情况一致。
  • 当把第二个Timer的吞吐量改为每分钟为200时,每个线程组可单独控制。
  • All active threads(shared) 将设置的吞吐量,分配到活跃的线程上(所有线程组的所有线程),所有线程都会在所有活跃线程运行结束之后即所有线程结束之后,等待合理时间(为了控制吞吐量)再次运行。 类似全场景的多次延迟释放,因为需要等待所有活跃线程运行结束,按照上述示例分析如下:
  • 在压测过程中,可以看到不会有多个Sampler的数据同时变化。
  • 已经发起过请求的线程会被暂停在第一个Sampler上。
  • 全场景的Target Throughput是为每分钟100,且多个Timer的配置保持一致。
  • All active threads in current thread group(shared) 将设置的吞吐量,分配到活跃的线程上(当前线程组的活跃线程),所有线程都会在所有活跃线程运行结束之后即所有活跃线程结束之后,等待合理时间(为了控制吞吐量)再次运行。 当前线程组中,活跃线程组中线程结束之后,再等待一点时间运行。
  • 线程组的Target Throughput为每分钟100,但每个线程会考虑全局其他活跃线程。
  • 线程组的吞吐量可以单独配置和控制。
  • All active threads 全场景吞吐量控制驱动:多个线程组的业务模型类似,且全场景的吞吐量固定,即可拆分到单个线程组的均匀吞吐量。 单机并发线程是50,Target/2替换为脚本中的值,即单机上的吞吐量变成脚本中的一半为每分钟50。全局的吞吐量不变化仍然为每分钟100。当有多个线程组的时候,还会多个线程组累加。 单机并发线程是50,单机上的吞吐量为每分钟100,全局吞吐量变为脚本中的值×IP数,即为每分钟200。当有多个线程组的时候,还会多个线程组累加。 All active threads(shared) 全场景吞吐量不区分线程组,略低于多线程组配置值叠加。 线程组1配置是100,线程组2配置是200,则全局为150,即两个线程组的均值。 线程组1配置是100,线程组2配置是200,则单机为(100+200)/2,全局为300,但是单机多个Sampler达到均衡的时间更长。 All active threads in current thread group(shared) 线程组的吞吐量考虑全局活跃,略低于多线程组配置值叠加。 线程组1配置是100,线程组2配置是200,则全局为300,是线程组1和2的配置数累计之和。 线程组1配置是100,线程组2配置是200,则单机为100+200,全局为600,但是单机多个Sampler达到均衡的时间更短。