性能测试工具 Jmeter 测试 Dubbo 接口脚本编写

目录

前言:

1、背景

2、工具准备

3、创建一个 maven 项目,此处可以创建一个 quickstart,参考截图

4、以上配置完毕后,开始撸代码

5、上面那个类是不需要从 jmeter 中获取参数,如果要从 jmeter 中获取相关的参数,可以参考下面这个类

6、调试代码

7、调试通之后,将代码打成 jra 包

8、因为步骤 7 中引入的第三方的 jar 包都放在了 lib-dependency 中,所以需要指定 jmeter 启动的时候,加载这个目录下的 jar 包

9、启动 jmeter,创建一个 java 请求,

10、此处可以把参数放在 csv 文件里,然后测试各种不同的场景

11、以上做完之后,简单调试下脚本,能够正常运行,然后将相关的依赖,脚本,数据文件传到压测机上,调整线程数,进行正式的压测


前言:

 性能测试是评估系统在不同负载条件下的性能和稳定性的关键环节。JMeter是一个流行的性能测试工具,可以用于测试Dubbo接口的性能。

1、背景

公司大部分的服务都是非 HTTP 的接口,都是 dubbo 接口,如今需要对一些接口做性能测试。

2、工具准备

Jmeter 3.2、 Java IDE(本文采用 IDEA),Maven 作为包管理工具

3、创建一个 maven 项目,此处可以创建一个 quickstart,参考截图

创建好之后,大概的工程结构是这样的:


其中,resource 中存放 dubbo 配置文件。
说到 resources,此处有一个坑,dubbo-config.xml 中的这个 xsd 文件,由于 code.alibabatech.com 已经停止了服务,需要使用下载一个 xsd 然后进行本地导入。此处也可以不用下载,直接在 pom 文件中,配置 dubbo 的依赖,然后下载 dubbo.jar,解压后就会有 dubbo.xsd 文件,拷贝出来即可,参考下图

pom.xml 文件配置

<dependencies><dependency><groupId>junit</groupId><artifactId>junit</artifactId><version>4.12</version><scope>test</scope></dependency><!--jmeter依赖的jar包--><dependency><groupId>org.apache.jmeter</groupId><artifactId>ApacheJMeter_core</artifactId><version>3.2</version><exclusions><exclusion><groupId>org.codehaus.groovy</groupId><artifactId>groovy-all</artifactId></exclusion><exclusion><groupId>commons-math3</groupId><artifactId>commons-math3</artifactId></exclusion><exclusion><groupId>commons-pool2</groupId><artifactId>commons-pool2</artifactId></exclusion></exclusions></dependency><!-- https://mvnrepository.com/artifact/com.alibaba/dubbo --><dependency><groupId>com.alibaba</groupId><artifactId>dubbo</artifactId><version>2.5.3</version><exclusions><exclusion><artifactId>spring</artifactId><groupId>org.springframework</groupId></exclusion></exclusions></dependency><!-- https://mvnrepository.com/artifact/com.101tec/zkclient --><dependency><groupId>com.101tec</groupId><artifactId>zkclient</artifactId><version>0.3</version><exclusions><exclusion><artifactId>zookeeper</artifactId><groupId>org.apache.zookeeper</groupId></exclusion></exclusions></dependency><!-- https://mvnrepository.com/artifact/org.apache.jmeter/ApacheJMeter_java --><dependency><groupId>org.apache.jmeter</groupId><artifactId>ApacheJMeter_java</artifactId><version>3.2</version><exclusions><exclusion><groupId>commons-math3</groupId><artifactId>commons-math3</artifactId></exclusion><exclusion><groupId>commons-pool2</groupId><artifactId>commons-pool2</artifactId></exclusion></exclusions></dependency><!--spring依赖的jar包--><dependency><groupId>org.springframework</groupId><artifactId>spring-aop</artifactId><version>${spring.version}</version></dependency><dependency><groupId>com.alibaba</groupId><artifactId>fastjson</artifactId><version>1.2.36</version></dependency><dependency><groupId>org.springframework</groupId><artifactId>spring-beans</artifactId><version>${spring.version}</version></dependency><dependency><groupId>org.springframework</groupId><artifactId>spring-core</artifactId><version>${spring.version}</version></dependency><dependency><groupId>org.springframework</groupId><artifactId>spring-context</artifactId><version>${spring.version}</version></dependency><dependency><groupId>org.springframework</groupId><artifactId>spring-context-support</artifactId><version>${spring.version}</version></dependency><dependency><groupId>org.springframework</groupId><artifactId>spring-expression</artifactId><version>${spring.version}</version></dependency><dependency><groupId>org.springframework</groupId><artifactId>spring-test</artifactId><version>${spring.version}</version></dependency></dependencies>

以上 pom 文件配置都是一些基本的配置,没有配置要测试的接口的依赖的 jar 包,实际操作过程中,需要加上。

dubbo-config.xml 的配置:

<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:dubbo="http://code.alibabatech.com/schema/dubbo"xsi:schemaLocation="http://www.springframework.org/schema/beanshttp://www.springframework.org/schema/beans/spring-beans.xsdhttp://code.alibabatech.com/schema/dubbohttp://code.alibabatech.com/schema/dubbo/dubbo.xsd"><dubbo:application name="要测试接口的应用名" owner="某人"/><dubbo:monitor protocol="registry"/><!-- 使用注册中心暴露发现服务地址 --><dubbo:registry address="zookeeper://zk的地址"/><!-- 生成远程服务代理,可以和本地bean一样使用demoService --><dubbo:reference id="iPromiseDubboService"interface="com.dmall.promise.dubbo.IPromiseDubboService" timeout="5000"check="false"/></beans>

4、以上配置完毕后,开始撸代码

需要继承 Jmeter 的 AbstractJavaSamplerClient 类,并实现 runTest 方法

public class QueryTimeInfoBySlotId extends AbstractJavaSamplerClient {private static final ApplicationContext context = new ClassPathXmlApplicationContext("dubbo-config.xml");private static IPromiseDubboService iPromiseDubboService;public void setupTest(JavaSamplerContext arg0){iPromiseDubboService=(IPromiseDubboService)context.getBean("iPromiseDubboService");}public SampleResult runTest(JavaSamplerContext javaSamplerContext) {SampleResult sr = new SampleResult();Long timeSlotId=20000l;try{sr.sampleStart();//此处可以增加请求的label,也可以就这样// sr.setSampleLabel(title);PromiseRemoteResponse<TimeInfo> responseData=iPromiseDubboService.queryTimeInfoBySlotId(timeSlotId);if(responseData!=null && "0000".equals(responseData.getCode())){sr.setSuccessful(true);sr.setResponseData("code: " + responseData.getCode()+"message: " + responseData.getMessage(),"utf-8");}else {sr.setSuccessful(false);}sr.sampleEnd();}catch (Exception e){e.printStackTrace();}return  sr;}public  void teardownTest(JavaSamplerContext arg0){}
}

5、上面那个类是不需要从 jmeter 中获取参数,如果要从 jmeter 中获取相关的参数,可以参考下面这个类

public class QueryAllOptionalPeriod extends AbstractJavaSamplerClient {private static final ApplicationContext context = new ClassPathXmlApplicationContext("dubbo-config.xml");private static IPromiseDubboService iPromiseDubboService;// 该方法设置的参数,都会出现在jmeter的参数列表中,并且展示相关设置的默认值public Arguments getDefaultParameters(){Arguments params = new Arguments();params.addArgument("title","casetitle");params.addArgument("erpStoreId", "110");params.addArgument("latitude", "116.435292");params.addArgument("longitude","39.994951");params.addArgument("saleType","1");return params;}public void setupTest(JavaSamplerContext arg0){iPromiseDubboService=(IPromiseDubboService)context.getBean("iPromiseDubboService");}public SampleResult runTest(JavaSamplerContext javaSamplerContext) {SampleResult sr = new SampleResult();//从jmeter 中获取相关的参数,组装后,调用相关的接口long erpStoreId=Long.parseLong(javaSamplerContext.getParameter("erpStoreId"));Double latitude=Double.parseDouble(javaSamplerContext.getParameter("latitude"));Double longitude=Double.parseDouble(javaSamplerContext.getParameter("longitude"));String title=javaSamplerContext.getParameter("title");Integer saleType=Integer.parseInt(javaSamplerContext.getParameter("saleType"));System.out.println("param is :  tilte is : " + title+"erpStoreId: " +  erpStoreId+ "latitude : "+ latitude + "longitude: " + longitude +"saleType: " +saleType);PromiseVO promiseVO = new PromiseVO();promiseVO.setErpStoreId(erpStoreId);Location location = new Location();location.setLongitude(longitude);location.setLatitude(latitude);promiseVO.setUserLocation(location);promiseVO.setSaleType(saleType);try{sr.sampleStart();sr.setSampleLabel(title);PromiseRemoteResponse<List<OptionalPeriod>> responseData=iPromiseDubboService.queryAllOptionalPeriod(promiseVO);if(responseData!=null && "0000".equals(responseData.getCode())){sr.setSuccessful(true);sr.setResponseData("code : " + responseData.getCode() + "message: " + responseData.getMessage(),"utf-8");}else{sr.setSuccessful(false);}sr.sampleEnd();}catch (Exception e){e.printStackTrace();}return sr;}public  void teardownTest(JavaSamplerContext arg0){}}

6、调试代码

写完了,固然可以打成一个 jar 包,然后传到 jmeter 的 lib/ext 下面进行调试,但是这样太麻烦了
这里可以直接用 main 方法调试
当这里 main 方法调试成功了后,再打 jar 包,上传到 jmeter 的相关路径,再进行测试,会高效很多。

public class TestMain {public static final void  main(String [] args){JavaSamplerContext arg0 = new JavaSamplerContext(new Arguments());QueryPreSaleOptionalPeriod test=new QueryPreSaleOptionalPeriod();test.setupTest(arg0);test.runTest(arg0);}
}

7、调试通之后,将代码打成 jra 包

注意,需要将 xsd,dubbo-config.xml 都要打在 jar 包里面,需要在 pom 文件中,还需要配置一些插件

<build><plugins><!--复制jar包插件,将使用到的jar包,复制到target/lib中--><plugin><groupId>org.apache.maven.plugins</groupId><artifactId>maven-dependency-plugin</artifactId><executions><execution><id>copy-dependencies</id><phase>prepare-package</phase><goals><goal>copy-dependencies</goal></goals><configuration><outputDirectory>${project.build.directory}/lib</outputDirectory><overWriteReleases>false</overWriteReleases><overWriteSnapshots>false</overWriteSnapshots><overWriteIfNewer>true</overWriteIfNewer></configuration></execution></executions></plugin><plugin><groupId>org.codehaus.mojo</groupId><artifactId>build-helper-maven-plugin</artifactId><version>1.8</version><executions><execution><id>add-resource</id><phase>generate-resources</phase><goals><goal>add-resource</goal></goals><configuration><resources><resource><directory>src/main/resources</directory><includes><include>*</include></includes></resource></resources></configuration></execution></executions></plugin><plugin><artifactId>maven-assembly-plugin</artifactId><version>2.4</version><configuration><descriptorRefs><descriptorRef>jar-with-dependencies</descriptorRef></descriptorRefs><archive><manifest><mainClass>TestMain.Main</mainClass></manifest></archive></configuration><executions><execution><id>make-assembly</id><phase>package</phase><goals><goal>single</goal></goals></execution></executions></plugin></plugins>

这样,执行 maven package 后,targer 下面会有两个东西,是我们需要的:

将此处的 jar 文件拷贝到 jmeter 的 lib/ext 里面
然后将 lib 下面的各种依赖的第三方的 jar 拷贝到 jmeter 的的 lib-dependency(自己创建一个就行)

8、因为步骤 7 中引入的第三方的 jar 包都放在了 lib-dependency 中,所以需要指定 jmeter 启动的时候,加载这个目录下的 jar 包

修改 jmeter.properties 中的 search_paths,配置相关的依赖的 jar 的路径

9、启动 jmeter,创建一个 java 请求,

10、此处可以把参数放在 csv 文件里,然后测试各种不同的场景

11、以上做完之后,简单调试下脚本,能够正常运行,然后将相关的依赖,脚本,数据文件传到压测机上,调整线程数,进行正式的压测

本文完
下面是 jmeter 在非 GUI 模式下的分布式测试配置和操作,可以参考。
性能测试过程中,一般是找个 linux 服务器,用命令行模式进行压测
jmeter non GUI 运行分布式压测
前期准备:master 和 slave 尽量使用相同的 jmeter 版本,避免一些奇葩的问题。

配置
slave 机器:启动 jmeter-server &(后台启动)
master 机器:配置 remote_host= slave 机器的 ip
PS: 此处如果 master 也要参与压测,需要启动 master 机器上的 jmeter-server,然后 remote_host 中需要配置 master 机器的 ip

启动命令,在 master 机器上执行:
方式一:指定其中一台机器或者多台
sh jmeter.sh -n -t ../../promise-test/testcase10.jmx -R 192.168.90.130
方式二:全部的 slave 都躁起来压测
sh jmeter.sh -n -t ../../promise-test/testcase10.jmx -r
Attention:注意 slave 和 master 的 host 配置,一定要有这条 host,
本机 ip hostname (不可以是 127.0.0.1,也不可以是 localhsot)

  作为一位过来人也是希望大家少走一些弯路

在这里我给大家分享一些自动化测试前进之路的必须品,希望能对你带来帮助。

(WEB自动化测试、app自动化测试、接口自动化测试、持续集成、自动化测试开发、大厂面试真题、简历模板等等)

相信能使你更好的进步!

点击下方小卡片

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/20382.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

bio、nio、aio、io多路复用

BIO-同步阻塞IO NIO-同步非阻塞IO 不断的重复发起IO系统调用&#xff0c;这种不断的轮询&#xff0c;将会不断地询问内核&#xff0c;这将占用大量的 CPU 时间&#xff0c;系统资源利用率较低 IO多路复用模型-异步阻塞IO IO多路复用模型&#xff0c;就是通过一种新的系统调用&a…

实现跨语言互动:如何在Python中调用Java的JavaParser库解析Java源代码

1、背景 在多语言开发环境中&#xff0c;我们经常需要进行跨语言的操作。有时&#xff0c;我们可能会在Python环境下需要使用Java的库或者功能。这个博客将展示如何在Python中调用Java的JavaParser库来解析Java源代码。 2、需求 在许多软件开发场景中&#xff0c;我们可能需…

如何在MySQL中安装示例数据库sakila

就像 SQLServer 示例数据库一样,MySQL 也有示例数据库,比如sakila;Sakila 数据库最初由 MySQL AB 文档团队的前成员 Mike Hillyer 开发,旨在提供一个标准模式,可用于书籍、教程、文章、示例等中的示例,它包含示例视图、存储过程和触发器。 以下是在服务器上安装sakila数…

【NLP】使用 LSA、PLSA、LDA 和 lda2Vec 进行主题建模

一、说明 本文是对主题建模及其相关技术的更新全面概述。在自然语言理解&#xff08;NLU&#xff09;任务中&#xff0c;有一个镜头层次结构&#xff0c;通过它我们可以提取含义 - 从单词到句子到段落到文档。在文档级别&#xff0c;理解文本的最有用方法之一是分析其主题&…

springboot 集成Druid的监控数据库连接池的最佳实践

免费的chatgpt福利送上 http://124.220.104.235:31105/web/chatgpt 1.数据库连接池介绍 1.1JDBC数据库连接池的必要性 在使用开发基于数据库的web程序时&#xff0c;传统的模式基本是按以下步骤 在主程序&#xff08;如servlet、beans&#xff09;中建立数据库连接 进行sql…

第6章 NVMe 介绍 6.1-6.3

6.1 AHCI 到 NVMe AHCI协议。NVMe协议。 HDD 和早期的 SSD 绝大多数都是使用SATA接口&#xff0c;跑的是AHCI&#xff0c;它是一种系统接口标准。 后来&#xff0c;AHCI 和 SATA 不能满足高性能和低时延 SSD 的需求&#xff0c;SSD 需要更快、更高效的协议和接口。因此 NVMe 出…

相对绝对定位父元素不设置宽度,根据子元素撑开(white-space: nowrap;)

要做一个如下的弹窗&#xff0c;很简单。但是当要切换成多语言或者数据是动态的话&#xff08;title可能会很长&#xff09;&#xff0c;那么弹窗固定宽度就不适用了。 有可能会出现下图的情况 也有可能出现下面的情况&#xff0c;文字被换行了&#xff08;有时候这种情况也是…

Python爬虫实战之原神公告获取

前言 好久不见了吧&#xff0c;博主最近也是成为了准高三&#xff0c;没有太多时间去创作文章了&#xff0c;所以这篇文章很有可能是高考前最后一篇文章了(也不一定&#x1f609;) 言归正传&#xff0c;本次文章主要讲解如何去爬取原神官网的公告(我不玩原神&#xff01;&…

Linux 常用命令

认识 Linux 目录结构 Linux 系统中&#xff0c;磁盘上的文件和目录被组成一棵目录树&#xff0c;每个节点都是目录或文件 Linux 是一个树形目录结构。Linux 上没有盘符概念&#xff0c;不分 C 盘等&#xff0c;根目录 \ 的地位相当与 Java 的 Object ——几个特殊的目录&…

符号化的正确姿势

GUI方式 将 .ips crash report 文件拖放到 Xcode > Window > Devices and Simulators > View Device Logs中, 然后导出 .crash 符号化文件. 使用条件: crash report 对应的 Archive 包是在本机构建的 symbolicatecrash symbolicatecrash 是一个 exec (可执行文件), …

【深度学习】受限玻尔兹曼机 (RBM) 初学者指南

一、说明 受限玻尔兹曼机&#xff08;Restricted Boltzmann Machine&#xff0c;RBM&#xff09;是一种基于能量模型的人工神经网络。它只有一个隐层&#xff0c;将输入层和隐层中的每个神经元互相连接&#xff0c;但不同层的神经元之间没有连接。RBM是一种无向的概率图模型&am…

【RocketMQ】005-Docker 部署 RocketMQ

【RocketMQ】005-Docker 部署 RocketMQ 文章目录 【RocketMQ】005-Docker 部署 RocketMQ一、部署1、拉取镜像MQ 镜像可视化平台镜像 2、创建挂载目录创建 nameserver 挂载目录创建 broker 目录创建 broker 配置文件目录 3、编辑配置文件4、启动服务启动 nameserver启动 broker启…