以前对接口做性能测试,接口都是同步处理的,请求之后等待响应结果就知道处理结果了,这样只要看这个接口是否异常,如果无异常无报错记录这个接口的响应时间、TPS等性能指标进行分析就可以了,最近在工作中遇到了异步处理的接口,逻辑是只要你请求参数全部合法,即返回成功。

通俗理解一下同步和异步的差别,举个小例子:

同步就是你妈喊你吃饭,你说等一下,然后你妈妈就一直在旁边等着你,专门等着你,等你做完了,一起去吃饭;

异步就是你妈喊你吃饭,你说等一下我忙完了就过去,你妈就走了,该干啥干啥去了,你忙完了,直接过去吃饭。

那么问题来了,这种接口,如果还像以前一样单纯的看接口的响应时间,就没有任何意义了,那么如何判断接口的性能呢?

先来描述一下被测系统:

这是一个专门负责发送消息的平台,包括短信消息和设备消息,大概架构如下:整个系统分为前端和后端,前端负责接收客户端的传参,把数据写入数据库并插入消息队列MQ;后端负责发送消息,队列MQ的消费,并更新数据库记录队列消息的消费时间及发送状态;接口全部为异步处理机制,下面以发送接口为例,简述整个测试过程:

1、制定测试方案

开始性能测试了,说明系统功能已经稳定,无遗留严重bug,此时需要对系统的需求做个调研分析,确定被测系统的性能测试方案,这里可以从需求出发,初步确定性能测试方案。确定测试场景为单接口场景,选取三个调用频率最高的接口来测试,和开发及运维等相关人员确定压测环境、服务器配置等数据,通过压力测试工具jmeter关注响应时间、每秒TPS及错误率,同时使用阿里云监控平台监控服务器内存和CPU使用情况。采用循序渐进增加线程数的方式得到接口的最大处理能力。

2、确定测试数据

为了尽量模拟真实场景,需准备不小于并发数百分之20的数据作为压测数据。

压测数据写在excel中

ps:这里有个坑,因为消息系统是给用户发送短信及消息,一不小心可能导致消息发送到真实用户了。此处有两个解决方案:a、让开发处理手机号校验的代码,把代码注释,手机号使用不存在的数字组合即可

b、开发做挡板,屏蔽调用第三方发送接口

3、根据测试场景编写测试脚本

共三个接口,https协议post请求

调用接口无需token,因此只需要把入参拼接排序加密签名即可,入参处理方法可以用java写好打包放到jmeter的lib目录,在beanshell中import进来直接调用即可

4、执行测试

测试脚本调试通过,就可以执行测试了。

按照常规接口的测试方式:就是从1个线程数开始,每次压测5分钟左右,压测过程中监控服务器cpu及内存占用情况,记录tps及响应时间,不断增加并发数,找到tps随并发数增大的拐点,即得出接口最大处理能力。

但是以上方式并不适用于这种异步的接口,那么如何处理呢?

此处通过查询数据库。当所有请求全部完毕了,查询数据库的发送信息表,检查请求时间字段和发送时间字段,请求时间字段记录该请求的调用时间,发送时间字段是后端发送消息后回写到数据库的发送时间,故请求时间字段和发送时间字段的差就是这一个请求的完整的响应时间,可以算出所有请求的平均时间、90%时间,第一条开始请求的时间到最后一条发送成功的时间之差就为持续压测时间,进而通过请求数能够计算出TPS,达到测试目的。

5、测试结果分析及调优

这部分和普通接口的压力测试是相同的,这里不多叙述。

对异步处理的http接口进行性能测试的更多相关文章

  1. 【总结】对异步处理的http接口进行性能测试

    以前对接口做性能测试,接口都是同步处理的,请求之后等待响应结果就知道处理结果了,这样只要看这个接口是否异常,如果无异常无报错记录这个接口的响应时间.TPS等性能指标进行分析就可以了,最近在工作中遇到了 ...

  2. 基于jmeter,jenkins,ANT接口,性能测试框架

    背景 公司计划推接口和性能测试,搭建这个性能测试框架框架是希望能够让每个人(开发人员.测试人员)都能快速的进行性能,接口测试,而不需要关注性能测试环境搭建过程.因为,往往配置一个性能环境可能需要很长的 ...

  3. Jmeter+jenkins如何快速搭建接口和性能测试持续集成解决方案-[基于windows篇]

    最近在用Jmeter本来想写一个详细的使用教程,突然看到有前辈已经写好了不错的教程,特此"借花献佛"整理出来分享给大家! Jenkins + Jmeter 构建接口.性能测试持续集 ...

  4. 【转】java接口的性能测试

    这周尝试了一把性能测试,之前都是测试网站的性能测试,java接口的性能测试还是头一次,学到了很多,特此分享一下. 主要用到了两个性能测试工具,一个是jmeter,一个是LoadRunner. 使用jm ...

  5. Android Asynchronous Http Client-Android异步网络请求客户端接口

    1.简介 Android中网络请求一般使用Apache HTTP Client或者采用HttpURLConnect,但是直接使用这两个类库需要写大量的代码才能完成网络post和get请求,而使用and ...

  6. 通过Jmeter对Dubbo接口进行接口及性能测试

    dubbo接口/性能测试 dubbo简介 zookeeper简介.安装及配置 dubbo服务端demo dubbo客户端调用 jmeter工程改造及接口调用 读取jmeter参数用于dubbo性能测试 ...

  7. java中的异步处理和Feature接口(一)

    背景介绍想象这样一个场景:你可能希望为你的法国客户提供指定主题的热点报道.为实现这一功能,你需要向 谷歌或者Twitter的API请求所有语言中针对该主题最热门的评论,可能还需要依据你的内部算法 对它 ...

  8. 使用jmeter对dubbo接口进行性能测试教程及常见问题处理

    一.   测试脚本编写 脚本可参考git项目: https://github.com/aland-1415/dubbo-interface-test.git 1. pom依赖 (注意添加的jmeter ...

  9. loadrunner做http接口的性能测试

    不用录制脚本的方法 步骤: 1.先打开Virtual User Generator——选择Web/HTTP协议,进入到主页面,这里不按照传统录脚本的方式输入url,所以直接叉掉录制脚本选项,进入下面的 ...

随机推荐

  1. iOS学习——iOS项目增加新的字体

    基本思路 在项目开发过程中,iOS系统自带的字体库可能不适应需求,需要导入其他的字体库.下面是iOS项目增加新的字体的基本思路,基本上分为三步: 将字体库添加到项目中 在info.plist中添加所需 ...

  2. 机器学习 | 聚类分析总结 & 实战解析

    聚类分析是没有给定划分类别的情况下,根据样本相似度进行样本分组的一种方法,是一种非监督的学习算法.聚类的输入是一组未被标记的样本,聚类根据数据自身的距离或相似度划分为若干组,划分的原则是组内距离最小化 ...

  3. 在DoNetCore MVC 中如何使用AutoMapper

    刚开始,按照在donet mvc 的方法写了一遍,发现行不通啊,于是百度了一下,找到这么一篇 https://stackoverflow.com/questions/41284349/automapp ...

  4. redis 订阅者与发布者(命令行)

    1.连接到redis ./bin/redis-cli -c -h 127.0.0.1 -p 6379 -a xxxxxxxx 2. 订阅管道 subscribe list1  订阅list1 3.发布 ...

  5. Hive使用过程中踩过的坑

    hive启动时错误1 Cannot execute statement:impossible to write to binary long since BINLOG_FORMAT = STATEME ...

  6. <choose><when><if>

    --说明:choose类似于switch,其中的when如果不符合则进入otherwise(类似于default),可以结合if标签使用. -- <select> -- SELECT * ...

  7. MySQL安装-glibc方式安装

    MySQL安装-glibc方式安装 版本说明:这里安装版本为MySQL-5.7系列的 mysql-5.7.27-linux-glibc2.12-x86_64.tar.gz 步骤 下载软件包 官网下载 ...

  8. Codeforces I. Inna and Nine(组合)

    题目描述: Inna and Nine time limit per test 1 second memory limit per test 256 megabytes input standard ...

  9. appium+python自动化63-使用Uiautomator2报错问题解决

    前言 appium desktop V1.7.1版本使用命令行版本启动appium后,使用Uiautomator2定位toast信息报错:appium-uiautomator2-server-v0.3 ...

  10. 【pathon基础】初识python

    一.python的起源 作者:Guido van Rossum(龟叔) 设计原则:优雅,简单,明确 二.解释型语言VS编译型语言 1.解释型语言:C#.python step1:程序员写代码: ste ...