网站首页 > 文章精选 正文
前面的这篇文章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性能测试:并发测试、压力测试,年薪30万杠杠滴 中一样,修改线程组中的数据和同步定时器进行性能测试即可
JMeter中要注意作用域,选中线程组的话是,线程组的所有请求,因此我们选中“登录”这个请求后---》右键----》添加---》定时器---》同步定时器,添加完成后如图
模拟用户组的数量:根据实际的情况填写,但要注意的是,超时单位为0时,用户组的数量要与线程组的数据匹配。例如:模拟用户数为2,线程组可以任意2的整数倍,2,4,6,8等都可以,但线程组中为7的话,因为没有设置超时机制,执行过程中会一直等待下一个数据的到来(第8个数据)
超时时间以毫秒为单位:最好设置超时机制,如果为0的话是没有超时机制,遇到以上用户数为2,线程数为7的情况下就会一直等待
四、最终结果要添加:察看结果树 进行调试,聚合报告为总的结果显示(如图添加请参考掌握这节JMeter性能测试:并发测试、压力测试,年薪30万杠杠滴)
猜你喜欢
- 2025-06-23 测试开发之自动化篇-有效测试数据管理
- 2025-06-23 测试用例编写方法(测试用例编写方法是什么)
- 2025-06-23 穿透与击穿:缓存世界的两场“攻击”,Java工程师如何见招拆招?
- 2025-06-23 用一场比赛来介绍CyclicBarrier和CountDownLatch区别
- 2025-06-23 JMeter脚本录制插件BlazeMeter(jmeter录制脚本的目的)
- 2025-06-23 如何避免数据库雪崩?高并发下的性能挑战与应对!
- 2025-06-23 性能测试工具Locust(性能测试工具loadrunner)
- 2025-06-23 软件性能测试常见面试题(软件性能测试的基本思路)
- 2025-06-23 DeepSeek性能测试实战:5分钟压测API接口,精准定位系统瓶颈!
- 2025-06-23 jmeter接口应用3:jmeter后置处理器-提取器
- 最近发表
- 标签列表
-
- newcoder (56)
- 字符串的长度是指 (45)
- drawcontours()参数说明 (60)
- unsignedshortint (59)
- postman并发请求 (47)
- python列表删除 (50)
- 左程云什么水平 (56)
- 计算机网络的拓扑结构是指() (45)
- 编程题 (64)
- postgresql默认端口 (66)
- 数据库的概念模型独立于 (48)
- 产生系统死锁的原因可能是由于 (51)
- 数据库中只存放视图的 (62)
- 在vi中退出不保存的命令是 (53)
- 哪个命令可以将普通用户转换成超级用户 (49)
- noscript标签的作用 (48)
- 联合利华网申 (49)
- swagger和postman (46)
- 结构化程序设计主要强调 (53)
- 172.1 (57)
- apipostwebsocket (47)
- 唯品会后台 (61)
- 简历助手 (56)
- offshow (61)
- mysql数据库面试题 (57)