使用Jmeter压测dubbo接口(不依赖dubbo插件)

1、dubbo 依赖

<dependencies>

<!-- Dubbo -->

<dependency>

<groupId>org.apache.dubbo</groupId>

<artifactId>dubbo</artifactId>

<version>2.7.8</version>

</dependency>

<!-- Zookeeper客户端 -->

<dependency>

<groupId>org.apache.curator</groupId>

<artifactId>curator-framework</artifactId>

<version>4.3.0</version>

</dependency>

<!-- Zookeeper客户端的Dubbo支持 -->

<dependency>

<groupId>org.apache.dubbo</groupId>

<artifactId>dubbo-dependencies-zookeeper</artifactId>

<version>2.7.8</version>

<type>pom</type>

</dependency>

<!-- 其他依赖,如日志等 -->

</dependencies>

2、继承AbstractJavaSamplerClient

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.dubbo.config.ApplicationConfig;

import org.apache.dubbo.config.ReferenceConfig;

import org.apache.dubbo.rpc.service.GenericService;

public class DubboGenericSampler extends AbstractJavaSamplerClient {

private GenericService genericService;

@Override

public void setupTest(JavaSamplerContext context) {

// 在测试开始前初始化Dubbo客户端

ApplicationConfig application = new ApplicationConfig("jmeter-dubbo-client");

ReferenceConfig<GenericService> reference = new ReferenceConfig<>();

reference.setApplication(application);

reference.setRegistry("zookeeper://127.0.0.1:2181");

reference.setInterface("com.example.DemoService");

reference.setGeneric(true);

// 初始化泛化服务

genericService = reference.get();

}

@Override

public SampleResult sample(JavaSamplerContext context) {

SampleResult results = new SampleResult();

results.setSampleLabel("Dubbo Generic Call");

try {

// 调用Dubbo服务

Object result = genericService.$invoke("sayHello",

new String[]{"java.lang.String"},

new Object[]{"World"});

results.setSuccessful(true);

results.setResponseData(String.valueOf(result).getBytes());

results.setResponseMessage("Success");

} catch (Exception e) {

results.setSuccessful(false);

results.setResponseMessage("Error: " + e.getMessage());

e.printStackTrace();

}

return results;

}

@Override

public void teardownTest(JavaSamplerContext context) {

// 清理资源,例如关闭Dubbo连接等(如果需要的话)

// 注意:Dubbo的ReferenceConfig通常不需要显式关闭,但如果有其他资源需要清理,请在这里进行

}

}

3、打成jar包并跟jmeter结合

  1. 将JAR文件放入JMeter的lib/ext目录

将编译好的JAR文件放入JMeter安装目录下的lib/ext文件夹中。这样,当JMeter启动时,它会自动加载这个JAR文件,并使其中的Sampler可用。

  1. 重启JMeter

每次向lib/ext目录添加新的JAR文件后,都需要重启JMeter以确保它能够识别并加载新的Sampler。

  1. 在JMeter中添加Sampler

重启JMeter后,按照以下步骤在测试计划中添加你的Sampler:

右键点击测试计划或线程组,选择"添加" -> "取样器" -> "Java请求"(注意:虽然这里可能看不到你自定义Sampler的具体名称,但所有继承自AbstractJavaSamplerClient的Sampler都会通过"Java请求"这个通用选项添加)。

在打开的Java请求界面中,你会看到一个"类名"字段。在这个字段中,输入你的Sampler类的完全限定名(包括包名),例如com.example.jmeter.DubboGenericSampler。

点击"应用"或"确定"保存设置。

相关推荐
a里啊里啊5 小时前
软考-软件评测师:知识点整理(八)——软件测试
软件测试·功能测试·压力测试·软考·软件评测师
Ew95a55o35 小时前
springMVC-RequestMapping注解
dubbo
弹简特8 小时前
【Fiddler抓包工具】一文通关Fiddler抓包工具【附:Fiddler结合jmeter接口测试实战】
jmeter·fiddler·接口测试·抓包
测试199818 小时前
性能测试方案设计的方法和思路
自动化测试·软件测试·测试工具·jmeter·测试用例·压力测试·性能测试
川石课堂软件测试19 小时前
软件测试|常见面试题整理
数据库·python·jmeter·mysql·appium·postman·prometheus
这是个菜比测试1 天前
jmeter无法访问内网接口
jmeter
qq_452396231 天前
第三篇:《JMeter断言:验证接口响应正确性》
android·jmeter
吃不胖爹1 天前
主动提交给搜索引擎,例如百度搜索资源平台、Google Search Console:验证站点、提交 sitemap,便于发现和收录
搜索引擎·百度·dubbo
是小章啊2 天前
Jmeter压测实战之HTTP_POST
网络协议·jmeter·http
0和1的搬运工3 天前
基于Java+SpringBoot+Vue+HTML5高校教师电子名片系统(源码+LW+调试文档+讲解等)/高校教师/电子名片/系统/教育科技/教育信息化/名片管理/电子身份/教师信息管理/校园信息化
spring cloud·tomcat·log4j·maven·intellij-idea·dubbo·java-consul