- Jmeter直连数据库
直接数据库的使用场景
直连数据库的关键配置
- 添加MYSQL驱动Jar包
方式一:在测试计划面板点击“浏览”按钮,将你的JDBC驱动添加进来
方式二:将MySQL驱动jar包放入到lib/ext目录下,
重启JMeter
配置数据库连接信息
- 添加方式-测试计划->线程组->(右键添加)配置元件JDBC Connection Configuration
Variable Name:mysql数据库连接池名称(JDBC请求时要引用)
Database URL:
jdbc:mysql://localhost:3306/tpshop2.0
- 组成:
协议+数据库IP+数据库端口+连接的数据库名称
- JDBC DRIVER class:
com.mysql.jdbc.Driver
(MySQL驱动包 位置固定格式---- 下拉框) - Username:root(连接数据库用户名,如实填写)
- Password:(MySQL数据库密码,如实填写,如果密码为空不写)
== 添加JDBC请求==
- 添加方式:测试计划—线程组—取样器—JDBC Request
Variable Name :数据库连接池的名字,需要与JDBC Connection Configuration的Variable Name Bound pool名字保持一致
练习1:
1、连接tpshop商城数据库获取商品名包含:小米手机5的商品id
准备工作:
1.启动tpshop数据库服务器
2.添加MySQL驱动jar包
操作步骤:
- 添加线程组
- 添加 JDBC Connection Configuration
- 添加 JDBC Request
- 添加查看结果树
练习2:
1、在tpshop首页中搜索商品名称包含"小米手机5",
请求url:http://192.168.234.129/Home/Goods/search.html
请求方法:GET
请求参数:q=“小米手机5”
2、 在搜索的响应数据中检查是否有该商品对应的商品链接:/Home/Goods/goodsInfo/id/237.html
(id:237需要通过数据库查询返回,才保证每次都是有效的)
编写JDBC脚本步骤(搜索指定商品,在返回结果中检查是否包含指定商品的ID的详情 URL):
- 1.添加线程组
- 2.添加 JDBC Connection Configuration
- 3.添加 JDBC request
- 4.添加 HTTP请求 - 搜索商品
- 5、断言响应数据是否包含指定商品的ID详情url(预期结果的商品id从数据库获取)
- 查看结果树
-
Jmeter逻辑控制器
-
如果(If)控制器
作用:If控制器用来
控制它下面的测试元素是否执行
位置:测试计划–>线程组—>(右键添加)逻辑控制器—>如果(If)控制器
参数介绍:
练习:
1.使用“用户定义的变量”定义一个变量name,name的值可以是“baidu"或”itcast"
2.根据name的变量值实现对应网站的访问。
操作步骤:
1.添加线程组
2.用户定义的变量
3.添加If控制器,判断name是否等于baidu
4.添加HTTP请求,用来访问百度
5.添加If控制器,判断name是否等于itcast
6.添加HTTP请求,用来访问传智播客
7.添加查看结果树
小结
(1) IF控制器的作用是什么?
- 来
控制它下面的测试元素是否执行
(2)使用“iF控制器” 的操作步骤?
- 1.添加线程组
- 2.用户定义变量
- 3.添加if控制器,判断name是否等于“baidu”
- 不勾选Interpret Condition,
“${name}”==“baidu”
- 勾选,
${__jexl3("${name}"=="itcast",)}
- 4.添加HTTP请求,访问百度
- 5.添加if控制器,判断name是否等于“itcast”
- 6.添加HTTP请求,访问itcast
- 7.查看结果树
- 循环控制器
作用:
通过设置循环次数,来实现循环发送请求
位置:测试计划–>线程组–(右键添加)逻辑控制器—>循环控制器
参数介绍:
案例:1.循环访问百度10次
操作步骤:
1.添加线程组
2.添加循环控制器----
设置循环次数
3.添加HTTP请求
4.添加查看结果树
小结
思考:线程组属性可以控制循环次数,那么循环器有什么用?
控制的
作用域不同
:线程组控制是线程组下的所有请求,循环控制器控制逻辑控制器下的所有请求如果线程组循环次数为M,循环控制器循环次数为N:
- 循环控制器下的HTTP请求运行:
M*N次
- 线程组下的其他HTTP请求运行:
M次
- ForEach控制器
作用:一般和
用户自定义变量
或者正则表达式提取器
一起使用,读取返回结果中一系列相关的变量值。该控制器下的取样器都会被
执行一次或多次
,每次读取不同的变量值。位置:测试计划—>线程组—>(右键添加)逻辑控制器—>ForEach控制器
练习:
1.有一组
关键字[hello,python,测试]
,使用用户定义的变量存储
2.要依次取出关键字,并在百度搜索,例如:https://www.baidu.com/s?wd=hel
步骤:
1.添加线程组
2.添加用户自定义的变量
3.添加ForEach控制器
4.添加HTTP请求
查看结果树
小结
(1)forEach控制器的作用是什么?
- 作用:一般和
用户自定义变量
或者正则表达式提取器
一起使用,读取返回结果中一系列相关的变量值。(2)使用“ForEach控制器”的操作步骤?
- 1.添加线程组
- 2.添加用户定义变量/正则表达式提取器
- 返回一组变量:
相同的变量名+连续的数字后缀
,如name_1,……,name_3- 3.添加forEach控制器
- 输入变量前缀:要读取的输入变量的
固定前缀
,如:name- 开始循环字段:要读取的输入变量
后缀数字的最小值-1
,如0- 结束循环字段:要读取的输入变量
后缀数字的最大值
,如3- 输出变量名称:要读取的输入变量后保存的
新变量名
,如word- 4.添加HTTP请求-百度
- 引用forEach控制器中保存的
新变量名
, 如${word}- 5.查看结果树
与
正则表达式
配合使用(案例2):
- 访问黑马首页http://www.heima.cn,获取首页中的地址信息,并全部保存下来
- 要依次取出地址关键字,并在百度搜索,例如:https://www.baidu.com/s?wd=地址
操作步骤:
1.添加线程组
2.添加HTTP请求1-heima
- 3.在HTTP请求1下面,添加正则表达式提取器,提取出所有的地址信息
- 4.添加ForEach控制器
- 5.添加HTTP请求2-百度
- 6.添加查看结果树
-
定时器
-
同步定时器
- 同步定时器:阻塞线程(累计一定的请求),当在
规定的时间内
达到一定的线程数量
,这些线程会在同一时间点一起释放
,瞬间产生很大的压力。- 提示:在Jmeter中叫做
同步定时器
,在Loadrunner中又叫集合点
。- 位置:测试计划–>线程组–>HTTP请求–>(右键添加)定时器—>Synchronizing Timer
练习1:
模拟100个用户同时访问百度首页,统计各种高并发情况下运行情况。
操作步骤:
- 1.添加线程组-设置线程数100人
- 2.添加HTTP请求
3.添加同步定时器,并发数可分别设置20/30人
- 设置并发线程数:同时发送请求的虚拟用户数
- 设置超时时间:
建议设置
:不设置的话,没有达到
设置的线程数会一直死等
。
不能设置太小
:等待时间后还没达到设置的线程数,会释放已到达的线程
。
- 4.添加查看结果树
- 5.添加监听器-聚合报告
小结
(1) 什么时候使用同步定时器?
测试抢购、秒杀或者抢红包
等高并发的场景
时使用(2)使用同步定时器的步骤?
- 添加线程组-设置线程数为n
- 添加HTTP请求-百度
- 添加同步定时器
- 设置并发线程数:同步发送请求的虚拟用户数
- 设置超时时间:
不设置的话,没有达到
设置的线程数会一直死等
。
不能设置太小
:等待时间后还没达到设置的线程数,会释放已到达的线程
。- 查看结果树
- 添加监听器-聚合报告
- 常数吞吐量定时器
作用:让JMeter按
指定的吞吐量
执行,以每分钟为单位位置:测试计划–>线程组—>HTTP请求–>(右键添加)定时器—>Constant Throughput Timer
练习:
(1) 一个用户以20 QPS(20次/S)的频率访问百度首页,持续一段时间,统计运行情况
步骤:
- 添加线程组-循环次数设置成永远
- 添加HTTP请求
- 添加常数吞吐量定时器(设置的吞吐量比不添加的小–这里设置20qps)
- 查看聚合报告
如果线程数改成2个,那么常量吞吐器定时器就要改成20*600/2=600
小结
(1)什么时候需要使用常数吞吐量定时器?
- 需要按指定的吞吐量发送请求时,可以使用吞吐量固定定时器
(2)使用常数吞吐量定时器的操作步骤
- 添加线程组-循环测试设置成永远
- 添加HTTP请求
- 添加常数吞吐量定时器
- 设置目标吞吐量:
每个用户每分钟发送的请求数
- 计算方法:要求
QPS * 60 / 线程数
- 添加监听器-聚合报告
- 固定定时器
案例:
(1)IHRM系统登录错误3次后,锁定1分钟,等待1分钟后重新输入正确的用户名密码登录成功
请求方法:POST
请求URL:http://ihrm-java.itheima.net/api/sys/login
请求头:Content-Type:application/json;charset=UTF-8
请求体:{“mobile”:“13800000002”,“password”:“888itcast.CN764%…”}操作步骤:
- 添加配置元件-HTTP信息头管理器
1.添加线程组
2.添加HTTP请求1-错误1次
3.添加HTTP请求2-错误2次
4.添加HTTP请求3-错误3次
5.添加HTTP请求4-正确用户名密码
- 6.在HTTP请求4下,添加固定定时器-
延迟1分钟执行
- 7.添加查看结果树
- 作业
步骤:
- 1、添加线程组
- 2、添加JDBC Connection Configuration -
配置数据库连接
- 3、添加jdbc request请求–
查询请假单总数量
- 4、添加HTTP请求-
请求请假单的接口
- 5、在HTTP请求下,
添加json断言--检查请假单的总数量和jdbc请求查询的请假单列表的总数量是否一致
- 6、添加查看结果树