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 是一款常用的性能测试工具,它可以帮助我们模拟多个并发用户同时访问接口,从而检测接口的负载和性能。在本文中,我们将介绍如何使用 JMeter 进行 Dubbo 接口的测试,并提供一些编写 JMeter 测试脚本的技巧和方法。

1、背景

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

2、工具准备

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

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

Jmeter 测试 Dubbo 接口脚本编写_第1张图片


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

Jmeter 测试 Dubbo 接口脚本编写_第2张图片


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

Jmeter 测试 Dubbo 接口脚本编写_第3张图片

pom.xml 文件配置


    
      junit
      junit
      4.12
      test
    

    
    
      org.apache.jmeter
      ApacheJMeter_core
      3.2
      
        
          org.codehaus.groovy
          groovy-all
        
        
          commons-math3
          commons-math3
        
        
          commons-pool2
          commons-pool2
        
      
    

    
    
      com.alibaba
      dubbo
      2.5.3
      
        
          spring
          org.springframework
        
      
    

    
    
      com.101tec
      zkclient
      0.3
      
        
          zookeeper
          org.apache.zookeeper
        
      
    
    
    
      org.apache.jmeter
      ApacheJMeter_java
      3.2
      
        
          commons-math3
          commons-math3
        
        
          commons-pool2
          commons-pool2
        
      
    

    
    
      org.springframework
      spring-aop
      ${spring.version}
    
    
      com.alibaba
      fastjson
      1.2.36
    
    
      org.springframework
      spring-beans
      ${spring.version}
    
    
      org.springframework
      spring-core
      ${spring.version}
    
    
      org.springframework
      spring-context
      ${spring.version}
    
    
      org.springframework
      spring-context-support
      ${spring.version}
    
    
      org.springframework
      spring-expression
      ${spring.version}
    
    
      org.springframework
      spring-test
      ${spring.version}
    
  

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

dubbo-config.xml 的配置:




    
    

    
    

    

    


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 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> 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 文件中,还需要配置一些插件


    
      
      
        org.apache.maven.plugins
        maven-dependency-plugin
        
          
            copy-dependencies
            prepare-package
            
              copy-dependencies
            
            
              ${project.build.directory}/lib
              false
              false
              true
            
          
        
      


      
        org.codehaus.mojo
        build-helper-maven-plugin
        1.8
        
          
            add-resource
            generate-resources
            
              add-resource
            
            
              
                
                  src/main/resources
                  
                    *
                  
                
              
            
          
        
      

      
        maven-assembly-plugin
        2.4
        
          
            jar-with-dependencies
          
          
            
              TestMain.Main
            
          
        
        
          
            make-assembly
            package
            
              single
            
          
        
      


    

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

Jmeter 测试 Dubbo 接口脚本编写_第4张图片


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

Jmeter 测试 Dubbo 接口脚本编写_第5张图片

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

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

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

Jmeter 测试 Dubbo 接口脚本编写_第6张图片

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

Jmeter 测试 Dubbo 接口脚本编写_第7张图片

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

Jmeter 测试 Dubbo 接口脚本编写_第8张图片

本文完
下面是 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)

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

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

(软件测试相关资料,自动化测试相关资料,技术问题答疑等等)

相信能使你更好的进步!

点击下方小卡片

【自动化测试交流】:574737577(备注ccc)icon-default.png?t=N6B9http://qm.qq.com/cgi-bin/qm/qr?_wv=1027&k=2VazabGG7Sqvk2AuzTBN_pECo6OTREI2&authKey=SxljQFrgAzikdNwwCgn2BYRlzUxXip9Q95p1XA1de3kwke9XIvZc4rf5fGISvZxP&noverify=0&group_code=574737577 

你可能感兴趣的:(自动化测试,自动化测试工具,软件测试,jmeter,dubbo,python,运维,开发语言,自动化)