之前用python+locust对脚本生成商品编码, 商品上架,购买商品进行编写脚本和压测;

开始是打算用Jmeter,后来遇到问题在 Jmeter如何读取JDBC多行并组成列表,作为下一个请求 一直卡在这里,今天终于突破 记录一下:

多方百度没有结果,最终经过过以为朋友指导,可以达成python脚本的效果;

总结:

虽然locust 没有向jmeter, LR等压测工具图表丰富,监听服务器情况等需要借助其他工作完成,在脚本灵活度上大大增加工作的效率;

第一步:

添加JDBC请求:详细参考另外一个博文

1.1添加mysql 链接驱动 \mysql-connector-java-5.1.47.jar

  

在线程组 增加 JDBC Connection Configuration:

在线程组 增加 JDBC Request:

添加debug Sample和查看结果树,运行脚本,查debug sample运行情况,如下:

在对于JDBC请求结果,发现同一个版本 也会出现不一样的情况,朋友结果是有些是有这个返回值gId_matchNr,而我的是没有

重点:

第二步:

思路是:通过BeanShell PostProcessor拿到JDBC查询结果,组合成一个列表,作为参数传入下一个请求;

vars.put() 接收是字符串,不接受其他类型

列表因此需要用:varObject()

引用参数直接通过${goodId}

5行:获取JDBC查询结果的“gId_#”的结果 即JDBC查询结果的总数,用于便利结果集

6行:转换成int类型

7行:通过log,可以在debug模式查过结果;

8行:创建一个列表,用于查询结果存储;

10行:遍历JDBC结果

11行:因为JDBC查询结果是:gId_1 代表第一个值,gId_2 代表第二个值,如此类推

12行:通过vars.get() 拿到每个值,“\"” 对冒号进行转义

14行:把拿到的每个商品号的值加入到列表里

16行:通过vars.putObject(“goodId”, glist) 赋予到新的变量

通过debug sample 查看到列表方式打印

最后的最后:

在上面脚本最后添加“log.info(glist)” 这行代码 出现下面报错信息,不知道怎么处理 有哪位朋友有解决方法吗?知道的大神 烦请留个言,谢谢

-- ::, ERROR o.a.j.u.BeanShellInterpreter: Error invoking bsh method: eval    Sourced file: inline evaluation of: ``  String tmp_id = vars.get("gId_#"); int num = Integer.parseInt(tmp_id); log.inf . . . '' : Error in method invocation: Method info( java.util.ArrayList ) not found in class'org.apache.logging.slf4j.Log4jLogger'
-- ::, WARN o.a.j.e.BeanShellPostProcessor: Problem in BeanShell script: org.apache.jorphan.util.JMeterException: Error invoking bsh method: eval Sourced file: inline evaluation of: `` String tmp_id = vars.get("gId_#"); int num = Integer.parseInt(tmp_id); log.inf . . . '' : Error in method invocation: Method info( java.util.ArrayList ) not found in class'org.apache.logging.slf4j.Log4jLogger'

Jmeter---后置处理器 BeanShell PostProcessor 获取JDBC结果(多行)并以列表传入另一个请求的更多相关文章

  1. Jmeter(十八) - 从入门到精通 - JMeter后置处理器 -下篇(详解教程)

    1.简介 后置处理器是在发出“取样器请求”之后执行一些操作.取样器用来模拟用户请求,有时候服务器的响应数据在后续请求中需要用到,我们的势必要对这些响应数据进行处理,后置处理器就是来完成这项工作的.例如 ...

  2. 二、Jmeter 后置处理器(BeanShell PostProcessor)

    1.新建JDBC Request,如下图所示: 重要的参数说明: Variable Name:数据库连接池的名字,需要与JDBC Connection Configuration的Variable N ...

  3. 通过JMETER后置处理器JSON Path Extractor插件来获取响应结果

    学生金币充值接口:该接口有权限验证,需要admin用户才可以做操作,需要添加cookie.cookie中key为登录的用户名,value从登录接口中获取,登陆成功之后会返回sign. 通常做法是在HT ...

  4. JMeter—后置处理器(十)

    参考<全栈性能测试修炼宝典JMeter实战>第六章 JMeter 元件详解中第五节后置处理器后置处理器是用来处理采样器发送的请求后得到的响应数据 一.Debug PostProcessor ...

  5. jmeter后置处理器 JSON Extractor取多个变量值

    1.需要获取响应数据的请求右键添加-后置处理器-JSON Extractor 2.如果要获取json响应数据多个值时,设置的Variable names (后续引用变量值的变量名设置)与JSON Pa ...

  6. Jmeter 后置处理器--jp@gc - JSON/YAML Path Extractor & JSON Extractor

    后置处理器--jp@gc - JSON/YAML Path Extractor 1.需要下载插件,地址: 解压后把对应jar包放置对应的lib和lib/ext目录下,重启Jmeter: 2.在需要提取 ...

  7. Jmeter(十七) - 从入门到精通 - JMeter后置处理器 -上篇(详解教程)

    1.简介 后置处理器是在发出“取样器请求”之后执行一些操作.取样器用来模拟用户请求,有时候服务器的响应数据在后续请求中需要用到,我们的势必要对这些响应数据进行处理,后置处理器就是来完成这项工作的.例如 ...

  8. Jmeter 后置处理器

    1.JSON Extractor Json extractor 后置处理器用在返回格式为 Json 的 HTTP 请求中,用来获取返回的 Json 中的某个值.并保存成变量供后面的请求进行调用或断言等 ...

  9. Jmeter后置处理器,正则表达式提取器的使用

    [使用场景]:下一个请求参数需要从上一个请求的响应数据中获取 [jmeter正则表达式说明]:使用perl正则表达式(可参考:http://www.runoob.com/perl/perl-regul ...

随机推荐

  1. 用python实现简单的计算器(加减乘除小括号等)

    需求:实现能计算类似 1 - 2 * ( (60-30 +(-40/5) * (9-2*5/3 + 7 /3*99/4*2998 +10 * 568/14 )) - (-4*3)/ (16-3*2) ...

  2. Codeforces 903 绝对值1e19longdouble算贡献 汉明距离交换两项是否可行

    A /*Huyyt*/ #include<bits/stdc++.h> #define mem(a,b) memset(a,b,sizeof(a)) #define pb push_bac ...

  3. mac安装测试myCat

      参考博文https://www.cnblogs.com/chanshuyi/p/head_first_of_mycat.html 1.下载解压mycat的mac版(位置不限) 2.cd进bin文件 ...

  4. STM32Cube IDE 汉字字体变小解决办法

    用STM32Cube IDE自动生成的工程,如果用汉字注释的话,字体会变小,如下图: 解决方法:选中变小的汉字->右击选择Preferences,如下图: 在弹出的对话框中可以看出默认的字体是C ...

  5. 聚合函数 Aggregate Function

    聚合函数是用来统计每个分组的统计信息,它们要跟 group by 一起使用,用来将每个分组所有数据 聚合 成一条统计数据. 包括 max/min/count/avg/sum 等. -- 按照部门进行分 ...

  6. ZROI 19.08.09模拟赛

    传送门 写在前面:为了保护正睿题目版权,这里不放题面,只写题解. A \(70pts:\) 维护一个栈,从一侧向另一侧扫描,如果新加入的元素与当前栈顶相同,则出栈,否则进栈.显然一个子串是括号序列,当 ...

  7. CodeForces-598D(BFS,染色)

    链接: https://vjudge.net/problem/CodeForces-598D 题意: Igor is in the museum and he wants to see as many ...

  8. Comet OJ - Contest #14题解

    Contest14的本质:区间覆盖+Tarjan( A 把距离公式两边平方即可 注意要long long code #include <algorithm> #include <io ...

  9. 浅谈Android的资源编译过程

    转载自 http://www.cnblogs.com/dyllove98/p/3144950.html 好长,记录下,一次看完感觉像没看一样 Android APK 一.APK的结构以及生成 APK是 ...

  10. datatable 和实体互转

    public static class ModelConvertHelper<T> where T : class,new() { public static List<T> ...