【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日

相关文章

  • 使用Java7的Files工具类和Path接口来访问文件的方法

    使用Java7的Files工具类和Path接口可以方便快捷地读写文件和目录等操作。下面将介绍使用Java7的Files工具类和Path接口来访问文件的方法。 创建Path对象 在使用Files工具类和Path接口访问文件之前,需要先创建Path对象。创建Path对象有三种方法: 通过Paths.get()方法 java Path path = Paths.g…

    Java 2023年5月20日
    00
  • Java 定时任务技术趋势详情

    Java 定时任务技术趋势详情 什么是 Java 定时任务技术 Java 定时任务技术是一种可以在预定的时间执行任务的技术,它通常用于在特定的时间或周期性地执行某些操作。在 Java 中,定时任务由 Java 自带的 java.util.Timer 类、java.util.concurrent.ScheduledExecutorService 类、Sprin…

    Java 2023年5月20日
    00
  • Spring-MVC异步请求之Servlet异步处理

    下面是对“Spring-MVC异步请求之Servlet异步处理”的完整攻略。 一、背景介绍 Spring框架提供了一种使得应用程序支持异步处理请求的方式,能够帮助提高应用程序的性能、吞吐量等指标。其中,支持异步请求的方式包括两种:Callable和DeferredResult,它们都是基于Servlet的异步原语API实现的。本篇攻略将主要介绍Servlet…

    Java 2023年5月16日
    00
  • 解读Spring事务是如何实现的

    下面是关于解读Spring事务实现的攻略。 什么是Spring事务? Spring事务是一种管理数据库事务的机制。Spring提供了一种将事务管理到服务层的方式,从而统一处理事务。它提供了在事务中进行数据操作的方法,当操作失败时,能够自动将已经对数据库做出的更改撤销。 Spring如何管理事务? Spring管理事务的核心是通过AOP,即面向切面编程,将调用…

    Java 2023年5月20日
    00
  • 关于Spring Data Jpa 自定义方法实现问题

    关于Spring Data JPA自定义方法实现问题的攻略,一般需要遵循以下步骤: 创建Repository 首先,需要定义一个继承自JpaRepository的Repository,并在其中声明需要自定义的方法。一个基本的Repository示例如下: package com.example.repository; import com.example.d…

    Java 2023年5月20日
    00
  • Java选择排序法以及实例详解

    Java选择排序法以及实例详解 选择排序是一种简单的排序算法,其基本思想是:每次从待排序的数组中选择最小值,将其放到数组的起始位置,然后从未排序的数组中选择最小值,将其放到已排序部分的下一个位置。依次类推,直到数组排序完成。 选择排序的Java实现 以下是Java实现选择排序的代码: public class SelectionSort { public s…

    Java 2023年5月19日
    00
  • Hibernate hql查询代码实例

    下面我来详细讲解“Hibernate hql查询代码实例”的完整攻略。 什么是Hibernate Hibernate是一个ORM框架(Object Relation Mapping),他能够将Java对象映射到关系数据库的数据表上,并提供了CRUD的操作方式。Hibernate可以用来解决JDBC API的繁琐操作。Hibernate的优点有: 减少了大量的…

    Java 2023年5月31日
    00
  • SpringBoot整合MyBatis超详细教程

    Spring Boot是一个快速开发框架,可以帮助开发人员快速构建Web应用程序。MyBatis是一个流行的ORM框架,可以帮助开发人员轻松地访问数据库。本文将详细讲解如何在Spring Boot应用程序中整合MyBatis,包括如何配置MyBatis、如何使用MyBatis等。 配置MyBatis 在Spring Boot应用程序中,可以使用MyBatis…

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