【Jmeter】按比例分配Api压测

yizhihongxing

先看

【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 Boot 自定义数据源DruidDataSource代码

    那么关于Spring Boot自定义数据源DruidDataSource的完整攻略,主要分为以下几个步骤: 导入相关依赖 首先,在Spring Boot项目中,需要导入Druid和JDBC相关的依赖。可以在pom.xml文件中加入如下代码: <!– 导入Druid数据源依赖 –> <dependency> <groupId&…

    Java 2023年5月20日
    00
  • 教你在一分钟之内理解Java Lambda表达式并学会使用

    教你在一分钟之内理解Java Lambda表达式并学会使用 什么是Lambda表达式 Lambda表达是Java 8引入的一种新特性,是一种简化代码的语法结构。它可以用来创建简洁、可读性强的函数式代码,适合于函数式编程。 Lambda表达式实际上是一个匿名函数,它不需要声明函数,直接在需要使用的地方定义即可。 Lambda表达式的语法 Lambda表达式的语…

    Java 2023年5月26日
    00
  • Java高级架构之FastDFS分布式文件集群详解

    Java高级架构之FastDFS分布式文件集群详解 FastDFS是一个开源的高性能分布式文件系统,可伸缩的分布式文件存储系统,是以跨平台、高效、高可靠性为特点的分布式文件系统,并以其优异性能成为国内外互联网公司分布式文件存储的不二之选。 概述 FastDFS是一个由跟踪服务器、存储服务器组成的分布式文件系统。跟踪服务器负责调度存储服务器,存储服务器则负责文…

    Java 2023年5月19日
    00
  • Java的Struts框架中登陆功能的实现和表单处理器的使用

    Java的Struts框架是一个MVC框架,它的优点是可以将业务逻辑和视图分开,方便管理。其中,登录功能是Web开发中一个非常基本的功能,而表单处理器则可以用于将表单请求中的数据映射到Java对象中。下面我将详细讲解Java的Struts框架中登陆功能的实现和表单处理器的使用的完整攻略。 Struts框架中登陆功能的实现 对于登陆功能的实现,Struts框架…

    Java 2023年5月20日
    00
  • javaGUI实现多人聊天功能

    下面是Java GUI实现多人聊天的完整攻略: 1. 确定实现方式 Java GUI实现多人聊天功能,可以采用Socket连接和Java Swing界面实现,也可以使用第三方库。这里我们介绍Socket连接和Java Swing界面实现的方式。 2. 创建Server端 首先,创建Server端代码,该部分主要用于监听客户端的连接请求,并进行相应的处理。其中…

    Java 2023年6月15日
    00
  • java连接Oracle数据库的工具类

    下面是详细讲解 “Java连接Oracle数据库的工具类” 的完整攻略: 1. 准备工作 首先需要在本地或者服务器上安装Oracle数据库软件并成功启动,并在其上创建一个数据库实例,同时需要知道该实例的连接信息(IP地址、端口号、数据库名称、用户名、密码)。 然后需要在Java项目中引入Oracle JDBC驱动的jar包,例如ojdbc6.jar。 2. …

    Java 2023年5月20日
    00
  • Java中 shuffle 算法的使用

    Java中 shuffle 算法的使用 shuffle算法是一种用于打乱集合顺序的算法。在Java中,我们可以使用Collections类提供的shuffle()静态方法来应用该算法。 shuffle()方法签名 public static void shuffle(List<?> list) shuffle()方法参数说明 list:要打乱顺序…

    Java 2023年5月19日
    00
  • Java Spring Boot请求方式与请求映射过程分析

    Java Spring Boot请求方式与请求映射过程分析 引言 Java Spring Boot是一款高效、快速、便捷的Java Web框架,通过对象依赖注入(DI)和面向切面编程(AOP)实现了模块化开发,提高了代码的简洁性和可维护性,常用于开发web应用程序、RESTful API接口等。 本文将详细讲解Java Spring Boot中的请求方式和请…

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