性能测试学习第六天-----JMeter拓展应用

一、TCP取样器

  服务器名称或IP:填写socket接口的ip
  端口号:写socket接口的端口号
  Re-use connection:是否重用链接,如果选择,同一个线程执行的所有请求都会使用一个tcp连接
  Re-use connection+close connection:每个请求结束后关闭连接
  End of line byte value:socket接口返回的数据结尾标识符的ascii码
  要发送的文本:发送的数据

   

二、定时器

     Jmeter中的定时器类似于loadrunner中的pacing值和think_time

  1)定时器是在每个sampler(采样器)之前执行的,而不是之后
  2)定时器是有作用域的;当执行一个sampler之前时,所有当前作用域内的定时器都会被执行。且所有的sampler执行前都会执行定时器
  3)如果希望定时器仅应用于其中一个sampler,则把该定时器作为子节点加入
  常用的定时器
  1,固定定时器:设置一个固定的延迟时间,单位ms
  2,同步定时器(synchronizing timer):在该定时器处,使线程等待,一直到指定的线程个数达到后,再一起释放。可以在瞬间制造出很大的压力。它和loadrunner的集合点差不多的功能
  3、常量控制器:可以控制每分钟tps的总量,限制最高

三、Jmeter常用的BeanShell:   https://www.cnblogs.com/qmfsun/p/5945302.html

  ◼ 前置处理器:BeanShell PreProcesser   预处理请求参数,例如参数之间有关联,参数a为奇数时,b=5;参数a为偶数时,b=10,如图。又例如:提前生成测试账号

  ◼ 采样器:BeanShell Sampler

  ◼ 后置处理器:BeanShell PostProcesser

  ◼ 断言:BeanShell断言

       1.获取内置变量---beanshell脚本中不用定义,可以直接使用的变量,常用的内置变量和方法如下 添加

    log:写日志到控制台和jmeter.log,如log.info(“xxxxx”);

    vars:操作jmeter变量

      vars.get(“ip”);             从jmeter中获取${skuId}变量的值

      vars.put(“name”,”test”);       将”test”保存到${name}变量中,可以用于新增变量,修改变量

    prev:获取前面sampler返回的信息

      getResponseDataAsString():       获取响应信息

      getResponseCode():          获取响应code

                

  但是不能在脚本中直接引用自定义变量,例如 String i=“1”; String sku=“${__Random(i,100,mysku)}”   ,直接引用脚本中自定义的 i 会报错。 

  2.打印日志、新增或修改参数

       

  3. 引用外部java文件,步骤:  

    //引用外部java文件
    source("D:/md5/Md5Util.java");
    //获取出原来的p_opt参数
    String str_opt = vars.get("p_opt");
    //调用Md5Util类中的getMd5Hex方法,将str_opt加密
    String md5_opt = Md5Util.getMd5Hex(str_opt);
    //将加密后的参数重新保存为一个mdt_opt参数,并放到vars中
    vars.put("md5_opt",md5_opt);

            

  4.引入外部jar包,步骤:

    1.“测试计划”里,Add directory or jar to classpath
    2.import 所需要的类名
    //导入类名
    import com.lee.util.Md5Util;
    //获取出原来的p_opt参数
    String str_opt = vars.get("p_opt");
    //调用Md5Util类中的getMd5Hex方法,将str_opt加密
    String md5_opt = Md5Util.getMd5Hex(str_opt);
    //将加密后的参数重新保存为一个mdt_opt参数,并放到vars中
    vars.put("md5_opt",md5_opt);

  5.bealshell断言 

    内置变量
    Failure:是否失败,boolean类型
    FailureMessage:失败日志,在断言失败时显示
    例:
    int stock = Integer.parseInt(vars.get("p_stock"));
    if (stock > 1500){
      Failure = true;
      FailureMessage = "库存数量超过了1500";
      // ResponseData是服务器返回的byte[]类型的数据,如果想打印,必须转换为String类型的,用new String(ResponseData)
      log.info(new String(ResponseData));
      //打印当前请求的url, SamplerData是String类型的数据
      log.info(SamplerData);
      }

                   

四、java请求,例如jdbc连接数据库批量插入数据,步骤:

  1.先使用eclipse新建java工程;

  2.新建文件夹lib,拖入jmeter中的四个jar包:ApacheJMeter_core.jar、ApacheJMeter_java.jar、slf4j-api-1.7.25.jar、jorphan.jar,分别在E:\apache-jmeter-5.1.1\lib\ext和E:\apache-jmeter-5.1.1\lib目录下;

  3.将mysql-connector-java-5.1.22-bin.jar也一并粘贴至lib文件夹下,选中这五个jar包,右键build in path;

  4.新建package,在package下新建类,注意新建类时需添加interface,搜索输入JavaSamplerClient,添加后,点击完成,即可看到类文件下已经生成了格式代码;

         

  5. 编写脚本,从之前为loadrunner写的jdbc连接数据库执行脚本中复制内容:setup中粘贴数据库连接等操作,teardown中粘贴关闭数据库连接操作,runtest中粘贴字符串替换 以及sql执行操作;导包和全局变量一并粘贴到前面,根据错误提示,增加try{}catch{}异常处理机制,增加main中传参。运行调试无误后,在public Arguments getDefaultParameters() 中增加与jmeter可识别交互的参数名称 并返回。

  6.脚本完成后,在eclipse中选中工程名称,右键,选择export-runnable java file, jar包和依赖包文件,注意下面选项:

       

  7.将导出的jar包和依赖包文件移动到 jmeter中lib\ext\下,重启jmeter;

  8.新建java请求,在类名称处就可以看到自己写的类名了,选择后,设置在getDefaultParameters() 中的变量就会识别出来,可以再当作Jmeter参数进行处理了。

      

 

 五、JMeter图形化可视报告插件应用

  使用Jmeter插件可以扩展Jmeter的功能

  插件官网: http://jmeter-plugins.org/downloads/all

  使用Jmeter插件管理器,可以自动下载并安装插件,更加方便简单

  使用方法:

  1,下载插件管理器对应的jar包,然后放在Jmeter的lib/ext目录下

  2,打开Jmeter,选项-插件管理器

  3,勾选对应的插件,等待下载完成,点击apply,等待重启Jmeter,即可使用

  4,添加tps监听器:事务控制器→添加→监听器 →jp@gc – Transaction per Second;

  5,添加tps监听器:事务控制器→添加→监听器 →jp@gc – Transaction per Second

  几个好用的插件:

    1> 3 Basic Graph:windows下可用的实时tps和响应时间的插件

    2> Custom JMeter Functions

    3> Random CSV Data Set Config

    4> PerfMon :服务端性能实时监控插件

 

posted @ 2019-08-16 16:12  青域  阅读(449)  评论(0编辑  收藏  举报