热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

jmetermysql查询结果提取_JMeter必掌握的关联技术:正则表达式,MySQL数据库提取数据,HTTP请求使用数据...

前面的这篇文章JMeter进行MySQL接口性能测试实战:数据库服务器测试介绍了JMeter进行MySQL数据库的访问进行性能测试,那么如果我想用从数据

前面的这篇文章JMeter进行MySQL接口性能测试实战:数据库服务器测试介绍了JMeter进行MySQL数据库的访问进行性能测试,那么如果我想用从数据库中得到的数据(用户名和密码)去进行登录操作的并发测试如何做呢?

也就是如图,我要提取JDBC Request的响应数据,那么这块儿就可以用到JMeter中的配置元件:正则表达式,进行上下文的关联

一、按照上文中《JMter进行MySQL接口性能测试实战:数据库服务器测试》添加完JDBC Request后,选中添加的JDBC Request 请求---右键---添加--后置处理器---正则表达式

1、名称和注释:任意

2、Apply to(作用于):

(1)Main sample and sub-samples:父节点取样器及对应子节点取样器

(2)Main sample only:仅作用于父节点取样器

(3)Sub-samples only:仅作用于子节点取样器

(4)JMeter Variable Name to use:作用于jmeter变量,输入框中输入变量名

3、要检查的响应字段:样本数据源

(1)主体: 接口响应主体内容,默认选择此项

(2)信息头:响应头的所有内容

(3)Body(unescaped):主体,响应的主体内容且替换了所有的html转义符,注意html转义符处理时不考虑上下文,因此可能有不正确的转换,不太建议使用

(4)Body as a Document:从不同类型的文件中提取文本,注意这个选项比较影响性能

(5)Request Headers:请求头的所有内容

(6)URL:是对sample的url进行匹配,也就是查看结果树里请求内容的第一行url,不包含data里的请求参数响应代码:http响应代码,如101,200,302,404,501等

(7)响应信息:http响应代码对应的响应信息,例如:OK, Found(HTTP/1.1 200 Ok;HTTP/1.1 302 Found)

4、引用名称(Reference Name):Jmeter变量的名称,存储提取的结果;即下个请求需要引用的变量名

5、引用方法:引用方法:${引用名称}

6、正则表达式(Regular Expression):使用正则表达式解析响应结果,“()”表示提取字符串中的部分值

如何填这里的数据呢,以下是常用的正则表达式:

(1)JMeter中没有特殊的情况,用以下两个正则基本上可以解决多数问题:(.*?) 或用(.+?) #以任意字符开始,匹配上一个后停止匹配(注意括号要用小写())

7、模板(Template):提取正则表达式中的那个值

$1$ :提取第一个值

$2$:提取第二个值

8、匹配数字(Match No):正则表达式匹配数据的结果可以看做一个数组,表示如何取值

(1)0:表示随机取值

(2)负数:表示提取所有符合条件的值

(3)1:表示第一个值

9、缺省值:匹配失败时候的默认值;通常用于后续的逻辑判断,一般通常为特定含义的数据,比如:ERROR,NULL等

二、正则表达式数据的引用(如图)

${name_pwd_g1}:提取第一个用户名的值

${name_pwd_g2}:提取第二个密码的值

三、关联上数据后就可以进行测试并发测试了,同第一篇JMeter性能测试的文章jmeter性能测试快速入门中一样,修改线程组中的数据和同步定时器进行性能测试即可

JMeter中要注意作用域,选中线程组的话是,线程组的所有请求,因此我们选中“登录”这个请求后---》右键----》添加---》定时器---》同步定时器,添加完成后如图

模拟用户组的数量:根据实际的情况填写,但要注意的是,超时单位为0时,用户组的数量要与线程组的数据匹配。例如:模拟用户数为2,线程组可以任意2的整数倍,2,4,6,8等都可以,但线程组中为7的话,因为没有设置超时机制,执行过程中会一直等待下一个数据的到来(第8个数据)

超时时间以毫秒为单位:最好设置超时机制,如果为0的话是没有超时机制,遇到以上用户数为2,线程数为7的情况下就会一直等待

四、最终结果要添加:察看结果树 进行调试,聚合报告为总的结果显示(如图添加请参考jmeter性能测试快速入门)



推荐阅读
  • MySQL中的MVVC多版本并发控制机制的应用及实现
    本文介绍了MySQL中MVCC的应用及实现机制。MVCC是一种提高并发性能的技术,通过对事务内读取的内存进行处理,避免写操作堵塞读操作的并发问题。与其他数据库系统的MVCC实现机制不尽相同,MySQL的MVCC是在undolog中实现的。通过undolog可以找回数据的历史版本,提供给用户读取或在回滚时覆盖数据页上的数据。MySQL的大多数事务型存储引擎都实现了MVCC,但各自的实现机制有所不同。 ... [详细]
  • 本文介绍了Paxos的世界中关于复制日志与状态机的概念和重要性。通过存储日志来实现数据的持久化,并通过日志流来记录数据的变化,而不是直接持久化数据本身。这样做的好处是简化了持久化存储的操作,并且方便多机之间的数据同步。 ... [详细]
  • 前景:当UI一个查询条件为多项选择,或录入多个条件的时候,比如查询所有名称里面包含以下动态条件,需要模糊查询里面每一项时比如是这样一个数组条件:newstring[]{兴业银行, ... [详细]
  • 本文介绍了Linux Shell中括号和整数扩展的使用方法,包括命令组、命令替换、初始化数组以及算术表达式和逻辑判断的相关内容。括号中的命令将会在新开的子shell中顺序执行,括号中的变量不能被脚本余下的部分使用。命令替换可以用于将命令的标准输出作为另一个命令的输入。括号中的运算符和表达式符合C语言运算规则,可以用在整数扩展中进行算术计算和逻辑判断。 ... [详细]
  • MyBatis多表查询与动态SQL使用
    本文介绍了MyBatis多表查询与动态SQL的使用方法,包括一对一查询和一对多查询。同时还介绍了动态SQL的使用,包括if标签、trim标签、where标签、set标签和foreach标签的用法。文章还提供了相关的配置信息和示例代码。 ... [详细]
  • OO第一单元自白:简单多项式导函数的设计与bug分析
    本文介绍了作者在学习OO的第一次作业中所遇到的问题及其解决方案。作者通过建立Multinomial和Monomial两个类来实现多项式和单项式,并通过append方法将单项式组合为多项式,并在此过程中合并同类项。作者还介绍了单项式和多项式的求导方法,并解释了如何利用正则表达式提取各个单项式并进行求导。同时,作者还对自己在输入合法性判断上的不足进行了bug分析,指出了自己在处理指数情况时出现的问题,并总结了被hack的原因。 ... [详细]
  • 本文介绍了将mysql从5.6.15升级到5.7.15的详细步骤,包括关闭访问、备份旧库、备份权限、配置文件备份、关闭旧数据库、安装二进制、替换配置文件以及启动新数据库等操作。 ... [详细]
  • 先看官方文档TheJavaTutorialshavebeenwrittenforJDK8.Examplesandpracticesdescribedinthispagedontta ... [详细]
  • 一句话解决高并发的核心原则
    本文介绍了解决高并发的核心原则,即将用户访问请求尽量往前推,避免访问CDN、静态服务器、动态服务器、数据库和存储,从而实现高性能、高并发、高可扩展的网站架构。同时提到了Google的成功案例,以及适用于千万级别PV站和亿级PV网站的架构层次。 ... [详细]
  • 网络请求模块选择——axios框架的基本使用和封装
    本文介绍了选择网络请求模块axios的原因,以及axios框架的基本使用和封装方法。包括发送并发请求的演示,全局配置的设置,创建axios实例的方法,拦截器的使用,以及如何封装和请求响应劫持等内容。 ... [详细]
  • 本文介绍了操作系统的定义和功能,包括操作系统的本质、用户界面以及系统调用的分类。同时还介绍了进程和线程的区别,包括进程和线程的定义和作用。 ... [详细]
  • 篇首语:本文由编程笔记#小编为大家整理,主要介绍了软件测试知识点之数据库压力测试方法小结相关的知识,希望对你有一定的参考价值。 ... [详细]
  • 上图是InnoDB存储引擎的结构。1、缓冲池InnoDB存储引擎是基于磁盘存储的,并将其中的记录按照页的方式进行管理。因此可以看作是基于磁盘的数据库系统。在数据库系统中,由于CPU速度 ... [详细]
  • 代理模式的详细介绍及应用场景
    代理模式是一种在软件开发中常用的设计模式,通过在客户端和目标对象之间增加一层中间层,让代理对象代替目标对象进行访问,从而简化系统的复杂性。代理模式可以根据不同的使用目的分为远程代理、虚拟代理、Copy-on-Write代理、保护代理、防火墙代理、智能引用代理和Cache代理等几种。本文将详细介绍代理模式的原理和应用场景。 ... [详细]
  • Android日历提醒软件开源项目分享及使用教程
    本文介绍了一款名为Android日历提醒软件的开源项目,作者分享了该项目的代码和使用教程,并提供了GitHub项目地址。文章详细介绍了该软件的主界面风格、日程信息的分类查看功能,以及添加日程提醒和查看详情的界面。同时,作者还提醒了读者在使用过程中可能遇到的Android6.0权限问题,并提供了解决方法。 ... [详细]
author-avatar
江西风起如斯
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有