服务器之家:专注于服务器技术及软件下载分享
分类导航

PHP教程|ASP.NET教程|Java教程|ASP教程|编程技术|正则表达式|C/C++|IOS|C#|Swift|Android|VB|R语言|JavaScript|易语言|vb.net|

服务器之家 - 编程语言 - Java教程 - springboot项目组引入JMeter的实现步骤

springboot项目组引入JMeter的实现步骤

2021-12-21 13:10HenryXiao8080 Java教程

本文主要介绍了springboot项目组引入JMeter的实现步骤,文中通过示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

一、前言

看到标题的小伙伴肯定很好奇,springboot项目中用JMeter能干什么,那么我先反问你JMeter能用来作什么?压测;接口自动化?,如果你能猜到这两点那你对JMeter肯定是有了一定的认知,同样你也猜对了,用它来做接口自动化
但是可能会有小伙伴会有疑问为什么不拿他来做压测,当然可能拿来做压测但是不建议在springboot项目中整合压测功能,毕竟压测本来就是一种多线程的形式而且极其消耗内存,spring项目本来就很重,所以得不偿失。当然对于压测我又另一种方案,就是容器化的分布式压测,这一块方案我会再后续的文章分享出,接下来我们先来谈谈如何在springboot项目中做接口自动化吧

在这篇文章中我详细介绍过JMeter engine启动原理,知道JMeter engine原理之后,是否我们可以这样做,在springboot项目引入JMeter开源组件包然后使用其开启engine的方法,自己开启engine,当然此时你的线程肯定是单线程,所以基本内存消耗很低,那么如何做?我们接着往下说

二、springboot项目引入JMeter完成接口自动化操作

首先导入JMeter对应的maven坐标

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
<properties>
    <jmeter.version>5.3</jmeter.version>
</properties>
 
<dependencies>
<dependency>
    <groupId>org.apache.jmeter</groupId>
    <artifactId>ApacheJMeter_http</artifactId>
    <version>${jmeter.version}</version>
    <exclusions>
        <exclusion>
            <groupId>org.apache.logging.log4j</groupId>
            <artifactId>log4j-slf4j-impl</artifactId>
        </exclusion>
    </exclusions>
</dependency>
<dependency>
    <groupId>org.apache.jmeter</groupId>
    <artifactId>ApacheJMeter_functions</artifactId>
    <version>${jmeter.version}</version>
</dependency>
<dependency>
    <groupId>org.apache.jmeter</groupId>
    <artifactId>ApacheJMeter_jdbc</artifactId>
    <version>${jmeter.version}</version>
</dependency>
<dependency>
    <groupId>org.apache.jmeter</groupId>
    <artifactId>ApacheJMeter_tcp</artifactId>
    <version>${jmeter.version}</version>
</dependency>
</dependencies>

JMeter engine启动原理介绍了StandardJMeterEngine标准的引擎类,通过创建这个对象就可以开启engine,当然事实并非如此简单

?
1
2
3
4
5
6
7
8
9
10
11
//创建engine
StandardJMeterEngine engine = new StandardJMeterEngine();
//将hashTree配置注入engine中
engine.configure(hashTree);
try {
 //执行engine开始运行
    engine.runTest();
} catch (JMeterEngineException e) {
    engine.stopTest();
    e.printStackTrace();
}

所以开启engine就这么短短的几步操作就行,但是上面需要HashTree对象传入,就是你的配置,关于HashTree的用法及使用,可以参考我写的这篇博文

一文搞懂JMeter engine中的HashTree配置

springboot项目组引入JMeter的实现步骤

HashTree有了之后,理论上是可以运行了,但是实际却会报错,因为JMeter engine开启会初始化配置文件,也就是我们熟知的jmeter.properties配置的内容,所以你可以在springboot项目的resource下创建jmeter目录存放jmeter.properties等配置

配置文件可以去github上去获取JMeter 配置

springboot项目组引入JMeter的实现步骤

好了配置有了,接下来我们需要先初始化jmeter.properties配置属性然后在开启jmeter engine就行

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
//初始化jmeter属性配置
private void initJMeterProperties() {
    if (!StringUtils.isEmpty(JMeterUtils.getJMeterProperties())){
        return;
    }
    try {
        InputStream inputStream = JMeterUtil.class.getResource("/jmeter/jmeter.properties").openStream();
        File tempFile = FileUtil.createTempFile(null);
        FileUtil.writeFromStream(inputStream,tempFile);
        //这里面loadJMeterProperties方法必须写成临时文件这样的形式,否则会获取不到jmeter.properties
        JMeterUtils.loadJMeterProperties(tempFile.getAbsolutePath());
        JMeterUtils.setJMeterHome(JMeterUtil.PATH);
        JMeterUtils.setLocale(LocaleContextHolder.getLocale());
    } catch (IOException e) {
        e.printStackTrace();
    }
}

在上面代码中必须通过创建临时文件的形式传入临时文件的路径,否则springboot打成jar无法找到路径从而报错

springboot项目组引入JMeter的实现步骤

在执行步骤2即可,但是会有一个问题engine.runTest()是一个空方法,那你如何接收运行的结果集数据呢?这里就要牵扯到jmeter后端监听器的作用了,JMeter后端监听器作用及原理可以参考这篇文章

后端监听器可以异步的接收jmeter engine运行的结果集,所以我们可以通过这个方式实现一个完整的接口自动化流程

这是关于我的springboot项目采用后端监听器的实现方式

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
public class CustomBackendListenerClient extends AbstractBackendListenerClient {
 
    private final List<SampleResult> queue = new ArrayList<>();
 
    //获得控制台内容。
    private PrintStream oldPrintStream = System.out;
    private ByteArrayOutputStream bos = new ByteArrayOutputStream();
 
    private void setConsole() {
        System.setOut(new PrintStream(bos));
    }
 
    private String getConsole() {
        System.setOut(oldPrintStream);
        return bos.toString();
    }
 // engine执行之前会进行前置处理器
    @Override
    public void setupTest(BackendListenerContext context) throws Exception {
        setConsole();
        super.setupTest(context);
    }
 //engine执行中的处理
    @Override
    public void handleSampleResults(List<SampleResult> sampleResults, BackendListenerContext context) {
     //结果集添加至集合中
        queue.addAll(sampleResults);
    }
 //engine结束后的后置处理器
    @Override
    public void teardownTest(BackendListenerContext context) throws Exception {
     //处理结果集中的数据并封装至JMeterRequestResult对象中
        RunJMeterRequestService runJMeterRequestService = CommonBeanFactory.getBean(RunJMeterRequestService.class);
        List<JMeterRequestResult> jMeterRequestResults = Lists.newArrayList();
        String testId = context.getParameter("testId");
        queue.stream().forEach(result -> {
            setRequestResult(result, jMeterRequestResults);
        });
        queue.clear();
        runJMeterRequestService.addDebugResult(testId, jMeterRequestResults);
        super.teardownTest(context);
    }
 
    private void setRequestResult(SampleResult result, List<JMeterRequestResult> jMeterRequestResults) {
        JMeterRequestResult metricResult = new JMeterRequestResult();
        Long responseTime = result.getEndTime() - result.getStartTime();
        metricResult.setUrl(result.getUrlAsString());
        metricResult.setResponseSize(((Integer) result.getBodySize()).toString());
        metricResult.setResponseTime(responseTime.toString());
        metricResult.setResponseResult(result.getResponseDataAsString());
        metricResult.setConsoleResult(getConsole());
        if (result instanceof HTTPSampleResult) {
            HTTPSampleResult res = (HTTPSampleResult) result;
            metricResult.setCookie(res.getCookies());
            metricResult.setRequestMethod(res.getHTTPMethod());
        }
        metricResult.setRequestData(result.getSamplerData());
        metricResult.setResponseHeader(result.getResponseHeaders());
        metricResult.setRequestHeader(result.getRequestHeaders());
        metricResult.setStatusCode(result.getResponseCode());
        jMeterRequestResults.add(metricResult);
    }
}

至此JMeter接口自动化可以通过此方案来实现,希望能对你有所启发

到此这篇关于springboot项目组引入JMeter的实现步骤的文章就介绍到这了,更多相关springboot项目组引入JMeter内容请搜索服务器之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持服务器之家!

原文链接:https://blog.csdn.net/weixin_40686603/article/details/114634552

延伸 · 阅读

精彩推荐
  • Java教程Java使用SAX解析xml的示例

    Java使用SAX解析xml的示例

    这篇文章主要介绍了Java使用SAX解析xml的示例,帮助大家更好的理解和学习使用Java,感兴趣的朋友可以了解下...

    大行者10067412021-08-30
  • Java教程20个非常实用的Java程序代码片段

    20个非常实用的Java程序代码片段

    这篇文章主要为大家分享了20个非常实用的Java程序片段,对java开发项目有所帮助,感兴趣的小伙伴们可以参考一下 ...

    lijiao5352020-04-06
  • Java教程Java实现抢红包功能

    Java实现抢红包功能

    这篇文章主要为大家详细介绍了Java实现抢红包功能,采用多线程模拟多人同时抢红包,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙...

    littleschemer13532021-05-16
  • Java教程Java BufferWriter写文件写不进去或缺失数据的解决

    Java BufferWriter写文件写不进去或缺失数据的解决

    这篇文章主要介绍了Java BufferWriter写文件写不进去或缺失数据的解决方案,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望...

    spcoder14552021-10-18
  • Java教程xml与Java对象的转换详解

    xml与Java对象的转换详解

    这篇文章主要介绍了xml与Java对象的转换详解的相关资料,需要的朋友可以参考下...

    Java教程网2942020-09-17
  • Java教程小米推送Java代码

    小米推送Java代码

    今天小编就为大家分享一篇关于小米推送Java代码,小编觉得内容挺不错的,现在分享给大家,具有很好的参考价值,需要的朋友一起跟随小编来看看吧...

    富贵稳中求8032021-07-12
  • Java教程Java8中Stream使用的一个注意事项

    Java8中Stream使用的一个注意事项

    最近在工作中发现了对于集合操作转换的神器,java8新特性 stream,但在使用中遇到了一个非常重要的注意点,所以这篇文章主要给大家介绍了关于Java8中S...

    阿杜7482021-02-04
  • Java教程升级IDEA后Lombok不能使用的解决方法

    升级IDEA后Lombok不能使用的解决方法

    最近看到提示IDEA提示升级,寻思已经有好久没有升过级了。升级完毕重启之后,突然发现好多错误,本文就来介绍一下如何解决,感兴趣的可以了解一下...

    程序猿DD9332021-10-08