Jmeter压测Thrift服务接口

本文介绍如何使用Apache JMeter进行Thrift服务接口的压力测试。通过Java二次开发,实现了Thrift服务的支持,详细步骤包括测试代码编写、依赖引入、代码重写及JMeter集成。适用于性能测试人员和技术爱好者。

此文已由作者夏鹏授权网易云社区发布。

欢迎访问网易云社区,了解更多网易技术产品运营经验。


Apache Jmeter是基于Java开发的性能测试工具,支持多种协议的测试,包括:Web(HTTP/HTTPS)、SOAP、FTP、Database(JDBC)、LDAP、Mail(POP3/IMAP)、JAVA;还提供了多种性能数据统计报表,使用简单方便简直是性能测试中居家旅行杀人越货之必备;但是~本次性能测试需求是Thrift服务接口,并不在Jmeter支持的协议范围内,继续用钟意的Jmeter完成Thrift服务的接口压测就需要进行二次开发来实现,以下简单介绍一下通过Jmeter进行扩展协议二次开发以支持Thrift服务接口的压测需求的过程。

Thrift是一个软件框架,用来进行可扩展且跨语言的服务的开发。它结合了功能强大的软件堆栈和代码生成引擎,以构建在 C++, Java, Go,Python, PHP, Ruby, Erlang, Perl, Haskell, C#, Cocoa, JavaScript, Node.js, Smalltalk, and OCaml 这些编程语言间无缝结合的、高效的服务。

Thrift也支持Java就好办了~


1.Java测试代码编写

1-1测试项目

rec包是Thrift服务类

ThriftClientTest是测试类

feab076a-cade-41a8-b7bd-3d26805394c6

1-2引入依赖

9a225bac-718a-4fa3-ab47-5d9566982650

1-3测试代码

测试类需要继承Jmeter的AbstractJavaSamplerClient类,然后重写以下方法:

①public void setupTest(JavaSamplerContext context);初始化方法,用于初始化性能测试的每个线程,每个线程前都会执行一次。

初始化Thrift客户端

3b7c93e3-5e07-4cda-989b-4efde823f9e7

②public Arguments getDefaultParameters();设置入参,已设置的参数会显示在jmeter GUI的参数列表中。

设置本次测试接口需要参数化的参数user_id

00fa44d7-0fb6-4ca5-aefa-e23535cf1455


③public SampleResult runTest(JavaSamplerContext context);性能测试的线程运行体,测试执行主体,从context中获取参数,并调用被测方法,完成与服务器的交互。该方法是java Sampler实现的重点,执行次数取决于线程数和循环次数。

设置请求属性以及具体的调用逻辑

dd24a0a9-88b9-4f0a-a465-3d07438130cf

sampleStart()开始统计响应时间标记、sampleEnd()结束统计响应时间标记,两个时间戳之差就是一次java请求的响应时间,单位是ms。

System.out输出会显示在启动JMeter时的命令窗口内,有助于监控结果但过多的输出会影响性能的准确性。

④public void teardownTest(JavaSamplerContext context);测试结束时调用,每个线程执行一次。setupTest和teardownTest方法不需要时可以不写。

关闭相关的资源

f8131759-ec56-4187-b8bb-cb140e85b9f3

所有重写方法执行的先后顺序为:

getDefaultParameters() --> setupTest(JavaSamplerContext context) --> runTest(JavaSamplerContext context) --> teardownTest(JavaSamplerContext context)


1-4集成到Jmeter

com.netease.rec包和ThriftClientTest测试类分别打成jar、Thrift中的jar包 libthrift-0.9.3.jar, slf4j-api-1.7.12.jar放到apache-jmeter-2.13/lib/ext下


2.Jmeter建立测试计划

2-1重新启动Jmeter。新建Thread Group, 在Thread Group下,Thread Group -> Add -> Sampler -> Java Request,在Classname下选择新做的plugin的类名。

de7d143e-2f2a-42df-bcaa-3438b237e0bb?imageView&thumbnail=980x0

2-2最后,配置相应的线程数,循环次数,添加聚合报告就可以进行Thrift服务接口的压力测试了

8c841fd9-d928-4ac4-8e30-822a5c089b41


网易云免费体验馆,0成本体验20+款云产品! 

更多网易技术、产品、运营经验分享请点击


相关文章:
【推荐】 Android事件分发机制浅析(3)

转载于:https://www.cnblogs.com/163yun/p/9838416.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值