基于Jmeter的thrift-RPC接口测试
根据需求,产品部分功能采用thrift-RPC协议进行接口的增、删、改、查,前期采用Junit对其进行测试,为了提高RPC接口测试的简洁化和后期的性能测试需求,打算通过Jmeter的java类测试实现。
前期准备:
开发提供了IDL描述的Thrift文件:dataService.thrift,其中定义了相关接口函数及数据类型,如下:
enum VStatus {
ON,
OFF
} struct VData {
1: required string tablename;
2: required string time;
3: required string jsons;
4: optional VStatus status;
} struct VCondition {
1: required string tablename;
2: required i64 starttime;
3: required i64 endtime;
} service DataService {
string write(1: VData data);
string read(1: VCondition condition);
}
在本地部署thrift.exe并设置环境变量,之后在dataService.thrift所在的目录下执行:
<dependencies>
<dependency>
<groupId>org.apache.thrift</groupId>
<artifactId>libthrift</artifactId>
<version>0.11.0</version>
</dependency> <dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-test</artifactId>
</dependency>
<dependency>
<groupId>org.apache.logging.log4j</groupId>
<artifactId>log4j-api</artifactId>
<version>2.8.2</version>
</dependency>
<dependency>
<groupId>org.apache.logging.log4j</groupId>
<artifactId>log4j-core</artifactId>
<version>2.8.2</version>
</dependency> </dependencies>
之后手动加载本地Jmeter版本目录\Jmeter_Home\lib\ext中的ApacheJMeter_core.jar和ApacheJMeter_java.jar作为外部依赖包(注:直接maven加载相关版本的依赖包执行时存在冲突)
将之前生成的4个java文件导入项目,设置包名为:com.test.thrift.api,在项目包名下创建ReadRPC.java类,根据Jmeter中java类要求需要继承 AbstractJavaSamplerClient,代码如下:
package com.test.RPCTest; import com.test.thrift.api.DataService;
import com.test.thrift.api.VCondition; import org.apache.jmeter.config.Arguments;
import org.apache.jmeter.protocol.java.sampler.AbstractJavaSamplerClient;
import org.apache.jmeter.protocol.java.sampler.JavaSamplerContext;
import org.apache.jmeter.samplers.SampleResult;
import org.apache.thrift.protocol.TBinaryProtocol;
import org.apache.thrift.protocol.TProtocol;
import org.apache.thrift.transport.TSocket;
import org.apache.thrift.transport.TTransport; public class ReadRPC extends AbstractJavaSamplerClient{
private TTransport tTransport;
private DataService.Client dataService;
private TProtocol tProtocol;
private VCondition vCondition; @Override
public Arguments getDefaultParameters(){ //默认参数值,包括服务ip、端口、目标表、起止时间等
Arguments arguments=new Arguments();
arguments.addArgument("IP", "127.0.0.1");
arguments.addArgument("Port", "8888");
arguments.addArgument("TableName", "vle::test.trpc");
arguments.addArgument("StartTime", "1539752449");
arguments.addArgument("EndTime", "1539752449");
return arguments;
} @Override
public void setupTest(JavaSamplerContext context) { //初始化参数,并通过TTransport模式TBinaryProtocol二进制协议与服务端建立连接
// TODO Auto-generated method stub
String ip=context.getParameter("IP");
int port=context.getIntParameter("Port");
String tableName=context.getParameter("TableName");
long startTime=context.getLongParameter("StartTime");
long endTime=context.getLongParameter("EndTime");
tTransport=new TSocket(ip,port,30000);
vCondition=new VCondition();
try {
tTransport.open();
tProtocol=new tBinaryProtocol(tTransport);
dataService=new DataService.Client(tProtocol);
vCondition.setTablename(tableName);
vCondition.setStarttime(startTime);
vCondition.setEndtime(endTime);
} catch (Exception e) {
// TODO: handle exception
}
super.setupTest(context);
} @Override
public SampleResult runTest(JavaSamplerContext context) {
// TODO Auto-generated method stub
SampleResult sampleResult = new SampleResult();
sampleResult.setDataEncoding("utf8");
sampleResult.sampleStart();
try {
String msg=dataService.read(tCondition);//执行读操作,返回响应结果信息到msg if(null==msg){//为空判断
sampleResult.setSuccessful(false);
sampleResult.setResponseMessage("响应结果为空!");
sampleResult.setSampleLabel("RPC读取");
sampleResult.setResponseOK();
sampleResult.setResponseData("响应结果为空!");
sampleResult.setDataType(SampleResult.TEXT);
return sampleResult;
}
else {
sampleResult.setSuccessful(true);
sampleResult.setSampleLabel("RPC读取");
sampleResult.setResponseOK();
sampleResult.setResponseData(msg);
System.out.println("msg="+msg);
sampleResult.setDataType(SampleResult.TEXT);
return sampleResult;
} } catch (Exception e) {
// TODO: handle exception
sampleResult.setSuccessful(false);
e.printStackTrace();
}
finally{
sampleResult.sampleEnd();
}
return sampleResult;
} public void teardownTest(JavaSamplerContext context){
tTransport.close();//关闭连接
super.teardownTest(context);
} }
在main函数中调用ReadRPC相关函数,代码如下:
public static void main( String[] args )
{
JmeterRPC jrpc=new JmeterRPC();
jrpc.read(); } public void read(){
Arguments arguments=new Arguments();
arguments.addArgument("IP", "127.0.0.1");
arguments.addArgument("Port", "8888");
arguments.addArgument("TableName", "vle::test.trpc");
arguments.addArgument("StartTime", "1539752449");
arguments.addArgument("EndTime", "1539752449");
JavaSamplerContext context=new JavaSamplerContext(arguments);
ReadRPC rpc=new ReadRPC();
rpc.setupTest(context);
rpc.runTest(context);
rpc.teardownTest(context);
}
运行程序输出msg=[{".........相关响应数据.............."}]
调试成功后保存后,选中项目右键“Export”->“Java”->“Runnable JAR file”,点击“Next”,设置输出路径和依赖库,如下图所示:
备注:选择第一种方式将依赖包打在里面;
将打好的RPC.jar包拷贝到JMeter_Home\lib\ext下,启动jmeter控制台打印该jar信息,如下图所示:
启动完成后添加Java请求,显示读取类名,配置相关参数,如下图所示:
执行结果如下:
之后便可以通过该jar进行RPC相关接口测试,而且保证其他测试人员无需写代码便可进行测试。
基于Jmeter的thrift-RPC接口测试的更多相关文章
- 性能工具之Jmeter压测Thrift RPC服务
概述 Thrift是一个可互操作和可伸缩服务的框架,用来进行可扩展且跨语言的服务的开发.它结合了功能强大的软件堆栈和代码生成引擎,以构建在 C++, Java, Python, PHP, Ruby, ...
- 基于jmeter,jenkins,ANT接口,性能测试框架
背景 公司计划推接口和性能测试,搭建这个性能测试框架框架是希望能够让每个人(开发人员.测试人员)都能快速的进行性能,接口测试,而不需要关注性能测试环境搭建过程.因为,往往配置一个性能环境可能需要很长的 ...
- 基于Jmeter和Testlink的自动化测试框架研究与实施
关于测试框架搭建的详细过程,会在另一篇文章中详细介绍:http://www.cnblogs.com/leeboke/p/6145977.html 摘 要 目前基于Jmeter的接口自动化测试框架,大多 ...
- RPC接口测试(三) RPC接口测试
RPC接口测试 接口测试主要分HTTP和RPC两类,RPC类型里面以Dubbo较为知名.互联网微服务架构,两种接口都需要做接口测试的,不管是业务测试还是回归测试: Dubbo:Java栈的互联网公司比 ...
- 使用Jmeter测试thrift接口
术语描述 jmeter:一款性能压力测试工具,支持多种协议,java .http 等,但是不支持thrift thrift:跨语言的RPC调用框架,提供编译器,可以将thrift接口生成不同语言的接口 ...
- 基于Jmeter+maven+Jenkins构建性能自动化测试平台
一.目的: 为能够将相关系统性能测试做为常规化测试任务执行,且可自动无人值守定时执行并输出性能测试结果报告及统计数据,因此基于Jmeter+maven+Jenkins构建了一套性能自动化测试平台 ...
- 基于Rabbit实现的RPC
最近在学习项目中的通用技术,其中一个是在项目中会经常使用的基于RabbitMQ实现的RPC.这里一共有三个点要学习,分别是:RPC是什么?RabbitMQ是什么?如何使用RabbitMQ实现RPC.奔 ...
- 基于jmeter的性能测试平台(二) 一个构想
之前基于jmeter搭好了分布式测试平台,但是感觉还是很粗糙,打算给它穿点衣服. 整个架构差不多就像下面这个图. (1)基于python django做一个web页面,友好地管理测试过程 (2)con ...
- 转:基于Jmeter的MQTT测试插件
基于Jmeter的MQTT测试插件-上 1. Jmeter插件简介 Apache JMeter是Apache组织开发的基于Java的压力测试工具.下载 用于对软件做压力测试,它最初被设计用于Web应用 ...
随机推荐
- Java基础12-工具类;变长参数;IO
作业解析 取出整数的16进制表示形式 \u00ff /** * int2hex * */ public static String int2hex(int i) { String str = &quo ...
- JAVA学习笔记(4)—— 排序算法
排序,就是使一串记录,按照其中的某个或某些关键字的大小,递增或递减的排列起来的操作.排序算法,就是如何使得记录按照要求排列的方法. 排序算法大体可分为两种: 一种是比较排序,时间复杂度O(nlogn) ...
- VS2012发布网站详细步骤问题
http://blog.csdn.net/mrobama/article/details/43118387
- Unity优化之贴图
默认情况下当你把图片导入到unity中时,unity会自动把图片转换成最适合当前平台的压缩格式.如果你有一些特殊的需求,unity也提供了覆盖默认压缩格式的方法,如下图 在图片的Inspector窗口 ...
- 【Python】Flask中@wraps的使用
先说总结,白话来讲,@wraps相当于是装饰器的装饰器. python内置的方法使用解释,看起很复杂的样子┓( ´∀` )┏ def wraps(wrapped, assigned = WRAPPER ...
- GrayLog + Logspout + Docker 实现分布式日志聚合
前提条件:你的服务器上已经安装了Docker和Docker Compose 一.安装GrayLog(Docker方式) version: '2' services: mongodb: image: m ...
- springMVC上传
1.页面 2.开始上传按钮对应的JS 3.添加文件按钮的方法,下图中1是从fast中取到的文件名称,2是文件图片的路径 下面就是后台的一些类.方法等 4.bean层,生成的get和set方法我就不写了 ...
- loj题目总览
--DavidJing提供技术支持 现将今年7月份之前必须刷完的题目列举 完成度[23/34] [178/250] 第 1 章 贪心算法 √ [11/11] #10000 「一本通 1.1 例 1」活 ...
- 程序员不能忍996了!全民 fuck ,GitHub来说话
前两天有个Github超级火的一个项目,在一小时之内星标上千. https://github.com/997icu/996.ICU 截至目前 这个项目start数量超过63K.Issues5000 ...
- 高可用Redis(一):通用命令,数据结构和内部编码,单线程架构
1.通用API 1.1 keys命令和dbsize命令 keys * 遍历所有key keys [pattern] 遍历模式下所有的key dbsize 计算Redis中所有key的总数 例子: 12 ...