基于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应用 ...
随机推荐
- VS2015创建ASP.NET应用程序描述
你的 ASP.NET 应用程序 恭喜! 你已创建了一个项目 此应用程序包含: 显示“主页”.“关于”和“联系方式”之间的基本导航的示例页 使用 Bootstrap 进行主题定位 身份验证,如果选择此项 ...
- 记录一个nginx的配置
rt #user xiaoju; worker_processes ; #error_log logs/error.log notice; #error_log logs/error.log debu ...
- MySQL之排序、分组(五)
一.排序 格式:select * from 表 order by 字段 asc|desc 1.查询所有的商品进行排序(升序asc.降序desc) mysql> select * from pro ...
- Django组件之用户认证组件
一.auth模块 from django.contrib import auth django.contrib.auth中提供了许多方法,这里主要介绍其中的三个: 1.1 .authenticate( ...
- rsync问题
问题一: rsync: chgrp "/data/www/vhosts/go/.rest.qXYFW5" (in apache) failed: Operation not per ...
- 小程序+node+mysql做的小项目
git源码地址: https://github.com/songkangle/weixin_node 小程序页面 数据库 user表 dream表 node的express框架index.js var ...
- 考勤输入导入OA平台与考勤统计报表导出功能源代码
注:以某某公司为例,每日签到时间为8点整 每日签退时间为17点30分 规则:公司签到签退时间在OA平台中可以视实际情况调整,当天有请假并通过工作流审批通过为有效,当天因公外出并通过工作流审批通过为 ...
- n2n windows 编译安装文件
n2n安装 n2n原理编译版下载,可直接使用:windows下vpn客户端 n2n_v2_linux_x64 n2n_v2_Win32TAP网卡驱动 #linux环境编译yum install -y ...
- js事件流机制冒泡和捕获
JavaScript与HTML之间的交互是通过事件实现的.事件,就是文档或浏览器窗口中发生的一些特定的交互瞬间. 事件流 从页面中接收事件的顺序称为事件流. IE --> 事件冒泡流 Netsc ...
- Selenium自动化测试之元素定位
步骤: 1.通过前端工具,查看元素的属性 2.通过属性定位 iddriver.findElement(By.id("kw")) namedriver.findElement(By. ...