【Jmeter】按比例分配Api压测

先看

【Jmeter】基础介绍-详细

【Jmeter】Request1输出作为Request2输入-后置处理器

继续聊提出的第二个问题,即

  2.需要按比例分配API请求并发,以模拟真实的API压力场景

做压测的时候,一般的需求都是多个API同时压,不然也看不出真正的tps是多少啊。

比如虽然接口a的需求并发不高,500个用户才请求一次,但是特别耗性能,导致其他接口tps下降严重,所以压测的时候可以将比例调的很小,但是不能忽略它,只测并发请求高的接口

说会主题,如何按比例分配压测并发量呢?使用Jmeter可以有两种实现方式

先说第一种,通过线程组的方式控制:

线程组1配置:

【Jmeter】按比例分配Api压测

 线程组2配置:

【Jmeter】按比例分配Api压测

 区别就是线程数不一样,当然用循环次数也可以控制,区别可以看【Jmeter】基础介绍-详细

Request请求:

【Jmeter】按比例分配Api压测

 结果:

【Jmeter】按比例分配Api压测

 这里哪个请求在前完全随机,两个线程中互不干扰。

这种方式的好处就是完全并行,互不干扰,缺点就是基本没有使用场景,一般情况下,API都是有权限认证接口的,后面的接口需要依赖前面接口的输出(实现方式可以看【Jmeter】Request1输出作为Request2输入-后置处理器),这种完全隔离的方式显然无法满足需求,或者你需要自己写代码提前获取登录信息,不使用压测过程中登录返回的认证信息。

我们继续介绍第二种方式,其实就是按【Jmeter】Request1输出作为Request2输入-后置处理器中创建的线程组一样,只使用一个线程组,然后通过循环控制器来控制某个Api所占比例:

新建循环控制器:

【Jmeter】按比例分配Api压测

 调整参数达到按比例分配Api压力的目的:

【Jmeter】按比例分配Api压测

【Jmeter】按比例分配Api压测

 执行效果:

【Jmeter】按比例分配Api压测

 如上图所示,执行了一个Request1和两个Request2,而且是按顺序执行的,即这种方式可以满足【Jmeter】Request1输出作为Request2输入-后置处理器需求的同时使用。不过有两点需要注意:

  1. 这种方式按顺序执行时,变量(例如身份信息token)是会被覆盖的,即无法完全模拟多用户登录及身份信息的场景。
  2. 这种配置方式会导致api并发分配不均,即在时间段1全部请求都是Request1,时间段2全部请求都是Request2,虽然总量是按比例的,但是并不符合我们的需求。

以上两个问题,在我的测试场景中1没有影响,即用户1、2、3、4、5那个来请求Api对压测来说是不关心的,性能完全一样。这里的登录只是为了压测登录接口,同时生成一个token给下面的接口使用。问题2影响比较大,可以通过【Jmeter】基础介绍-详细中提到的Ramp-up时间参数来控制,首先按比例配置好循环控制器后,将线程数和循环次数配置为1,Ramp-up配置为0,即立刻启动,然后使用压测机跑一下用于估算一次压测流程的时间。得到这个时间后,就是我们在实际压测中需要填写到Ramp-up中的参数,比如一次完整的压测流程需要2s,我现在需要压测执行1000个线程,循环100次,即一共10w次请求,将Ramp-up时间设置为2s,即1000个线程将在2s内逐步启动,达到所有线程的启动时间覆盖第一个线程一次循环的整个时间段,来达到真实模拟多种请求并发执行的过程,解决以上提到的第二个问题。

 

原文链接:https://www.cnblogs.com/maerpao/p/17347084.html

本站文章如无特殊说明,均为本站原创,如若转载,请注明出处:【Jmeter】按比例分配Api压测 - Python技术站

(0)
上一篇 2023年4月25日
下一篇 2023年4月25日

相关文章

  • Spring Data JPA分页复合查询原理解析

    Spring Data JPA分页复合查询原理解析 在使用 Spring Data JPA 的过程中,分页和复合查询是经常用到的功能。本文将详细讲解 Spring Data JPA 分页和复合查询的原理,同时给出两个示例进行演示。 分页原理 Spring Data JPA 的分页功能基于 Spring Framework 的 PagingAndSorting…

    Java 2023年5月20日
    00
  • 如何使用Java诊断工具?

    使用Java诊断工具可以帮助我们定位Java应用性能和稳定性问题,下面是使用Java诊断工具的攻略与示例说明。 一、准备工作 在使用Java诊断工具之前,需要确保以下条件: 安装Java Development Kit(JDK); 对Java编程语言有一定的基础; 了解如何使用命令行工具。 二、使用Java诊断工具 1. JConsole JConsole是…

    Java 2023年5月11日
    00
  • 在Ubuntu系统下安装JDK和Tomcat的教程

    下面是在Ubuntu系统下安装JDK和Tomcat的教程。 1. 安装JDK 1.1 下载JDK 首先,我们需要到Oracle官网下载JDK的安装包。下载地址:https://www.oracle.com/java/technologies/javase/javase-jdk8-downloads.html 选择适合自己操作系统的对应版本下载。 1.2 安装…

    Java 2023年5月19日
    00
  • 在Spring中使用JDBC和JDBC模板的讲解

    下面我将为您详细讲解在Spring中使用JDBC和JDBC模板的完整攻略。 什么是JDBC? Java数据库连接(JDBC)是一种Java API,用于与关系数据库进行交互。它提供了一种标准的方法来与数据库进行通信,使得Java程序员可以轻松地与各种数据库进行交互,如MySQL,Oracle和Microsoft SQL Server等。 在Spring中使用…

    Java 2023年5月20日
    00
  • Java通过调用C/C++实现的DLL动态库——JNI的方法

    Java Native Interface(JNI)是Java平台提供的一种机制,用于在Java应用程序中调用非Java代码(如C或C++代码)。通过使用JNI,Java应用程序可以与本地库中的代码进行交互,从而实现更高级别、底层的操作。在这个攻略中,我们将会讲解如何使用JNI在Java中调用C/C++编写的DLL动态库,并提供两个简单的示例。 步骤1:编写…

    Java 2023年5月23日
    00
  • Java Class.forName()用法和newInstance()方法原理解析

    Java中的Class对象提供了一些强大的机制来处理编译时期未知的类,比如在运行时动态加载并实例化一个类。其中Class.forName()和newInstance()方法是两个非常重要的方法,本文将详细讲解它们的用法和原理。 Java Class.forName()方法 Class.forName()是Java反射机制中的核心方法之一,它可以根据类名动态加…

    Java 2023年5月26日
    00
  • Java实现文件的分割与合并

    下面是详细的讲解: 1.需求分析 在很多情况下,我们需要将大文件拆分成多个小文件进行存储或传输。因此需要实现一个文件分割与合并的工具。Java提供的File类可以很好地操作文件,但并不提供文件分割和合并的功能。下面我们就来讲讲如何在Java中实现文件分割与合并。 2.文件分割 文件分割就是将一个大文件切割成若干个小文件,方便存储和传输。Java中实现文件分割…

    Java 2023年5月20日
    00
  • java常用Lambda表达式使用场景源码示例

    Java常用Lambda表达式使用场景源码示例 什么是Lambda表达式? Lambda表达式是Java 8引入的新特性之一,它是一个匿名函数,可以传递到函数式接口中使用。Lambda表达式提供了一个简单而强大的语法来处理集合数据,比传统的循环语句更加简洁易懂。 Lambda表达式的语法格式为:(parameters) -> expression 或 …

    Java 2023年5月26日
    00
合作推广
合作推广
分享本页
返回顶部