以前对接口做性能测试,接口都是同步处理的,请求之后等待响应结果就知道处理结果了,这样只要看这个接口是否异常,如果无异常无报错记录这个接口的响应时间、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. java中的异步处理和Feature接口(一)

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

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

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

  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. SpringMVC 之拦截器和异常处理

    1. 文件上传 Spring 使用 Jakarta Commons FileUpload 技术实现了一个 MultipartResolver 实现类: CommonsMultipartResolver ...

  2. SpringMVC 之 RESTful 风格的增删改查

    1. 视图和视图解析器 视图解析器 请求处理方法执行完成后,最终返回一个ModelAndView对象,对于返回String,View 或 ModelMap 等类型的处理方法, SpringMVC 也会 ...

  3. Kubernetes网络框架

    // cmd/kubelet/app/server.go -1.func UnsecuredKubeletDeps(s *options.KubeletServer) (*kubelet.Kubele ...

  4. Codeforce 475 C. Kamal-ol-molk's Painting

    从最左上的点開始枚举长宽.... C. Kamal-ol-molk's Painting time limit per test 2 seconds memory limit per test 256 ...

  5. (2.2)学习笔记之mysql基础操作(登录及账户权限设置)

    本系列学习笔记主要讲如下几个方面: 本文笔记[三:mysql登录][四:账户权限设置][五:mysql数据库安全配置] 三.mysql登录 常用登录方式如下: 四.账户权限设置 (4.1)查看用户表, ...

  6. 查看Oracle的表中有哪些索引

    用user_indexes和user_ind_columns系统表查看已经存在的索引 对于系统中已经存在的索引我们可以通过以下的两个系统视图(user_indexes和user_ind_columns ...

  7. TCP/IP三次握手与四次挥手(转)

    一.TCP报文格式        TCP/IP协议的详细信息参看<TCP/IP协议详解>三卷本.下面是TCP报文格式图: 图1 TCP报文格式 上图中有几个字段需要重点介绍下:      ...

  8. beego——XSRF过滤

    跨站请求伪造,简称XSRF,是Web应用中常见的一个安全问题. 当前防范 XSRF 的一种通用的方法,是对每一个用户都记录一个无法预知的token数据, 然后要求所有提交的请求(POST/PUT/DE ...

  9. 再谈WinIO初始化异常

    再谈WinIO初始化异常     前段时间WinIO在我的新项目中总是初始化失败,有时候又是好好的,很让人费解.修改了源代码显示了很多调试信息后,也没有什么太多的收获.由于我们的工控卡必须要用这个库, ...

  10. java基本类型和包装器类

    java是一种面向对象语言,java中的类把方法与数据连接在一起,并构成了自包含式的处理单元.但在java中不能定义基本类型(primitive type),为了能将基本类型视为对象来处理,并能连接相 ...