性能测试工具 🔥Jmeter(七) - 从入门到精通 - 建立数据库测试计划实战<MySQL 数据库>(详解教程)

北京-宏哥 · 2025年02月25日 · 263 次阅读

1.简介

  在实际工作中,我们经常会听到数据库的性能和稳定性等等,这些有时候也需要测试工程师去评估和测试,上一篇文章宏哥主要介绍了 jmeter 连接和创建数据库测试计划的过程,宏哥在文中通过示例和代码非常详细地介绍给大家,希望对各位小伙伴和童鞋们的学习或者工作具有一定的指导和参考学习价值,遇到类似的问题脑子一片空白的童鞋们可以参考一下。这一篇宏哥就以 MySQL 数据为例结合上一篇的理论知识在这里带领小伙伴和童鞋们实战一下。这里宏哥为了增加小伙伴们的学习兴趣和便于记忆理解,因此列举了一个谍战剧中执行刺杀任务的场景,首先组成刺杀任务的小队,然后通过接头暗号建立联系,其次就开始执行刺杀任务,期间有核查组员的人物背景、其他组员支援、以及自己组员的牺牲、任务的变更等等,最后确认暗杀任务是否执行成功。

2.环境准备

1、MySQL 数据库
2、下载 mysql jdbc 驱动
3、JMeter

2.1 安装 MySQL

首先确保你已经安装好数据库 MySQL。如果没有可以参考宏哥的这篇文章:传送门。查看有没有安装 MySQL 命令:net start,打开控制台 (在开始,运行输入 cmd) 然后出入 “net start” 就是打开了服务看看列出来的有没有 MySQL 之类的如果没有,就是没有安装。如下图所示:

2.2JMeter

JMeter 安装启动好待用。

2.3 下载 MySQL 驱动

1、下载 MySQL 驱动。下载地址:https://dev.mysql.com/downloads/connector/j/
常用的包如下:
Windows 下 mysql-connector-java-5.1.7-bin.jar
Mac 下 MySQL Connector/J 没有对应的 Mac 版,可以选择 Platform Independent:mysql-connector-java-8.0.15.zip
注意:驱动包的版本一定要与你数据库的版本匹配,驱动版本低于 mysql 版本有可能会导致连接失败报错

2、解压下载的 MySQL 驱动,如下图所示:

3、将解压的 MySQL 的 jdbc 驱动(mysql-connector-java-8.0.20.jar),将其放到 D:\software\apache-jmeter-5.1.1\lib 目录下。如下图所示:

注意:敲黑板,敲脑壳啦!!!放完驱动以后,要记得重启 jmeter

3.建立数据库测试计划

  在本节中,您将学习如何创建基本的测试计划以测试数据库服务器和操作数据库(增、删、改、查)。本示例使用 MySQL 数据库驱动程序。要使用该驱动程序,必须将其包含的.jar 文件(例如mysql-connector-java-XXX-bin.jar)复制到 JMeter ./lib 目录。

3.1 新建测试计划

首先我们新建一个测试计划,并将其命名为:Test MySQLDB Plan,如下图所示:

3.2 在测试计划下添加驱动地址

在建立好测试计划以后,点击 “Browse...”,选择我们前边下载解压好的驱动路径,我们需要将驱动的地址(路径)添加到测试计划下边,如下图所示:

3.3 添加用户

新建完测试计划以后,我们前边也讲过了,这时候就要添加用户了。你要对每个 JMeter 测试计划进行的第一步是添加一个线程组(用户)。线程组告诉 JMeter 您要模拟的用户数量,用户应多久发送一次请求以及应发送多少次请求。这里就相当于谍战片中我们开始选择队员组队的过程,默认是一人一个小组,如果你觉得不够可以在控制面板修改人数等等。如下图所示:

3.4 添加 JDBC 连接配置

通过上边的操作,我们已经定义了用户挑选了队员组成了精干小组,然后我们必须定义这些用户(队员)所要去的目的地,和目的地建立联系。不要这些用户累死累活的干了半天的活,知不道是为谁干得活。在本部分中,你需要和目的地建立联系。我们需要设置一些字段,这些字段相当于谍战片中的接头暗号,例如:《智取威虎山》杨子荣与坐山雕的接头暗号:脸红什么?精神焕发。怎么又黄拉?防冷涂的蜡;长江长江我是黄河,等等。暗号对上了,才可以建立联系。否则认为有危险,不是建立联系,具体在测试中的表现就是报错了!!!,下边控制面板的参数字段在上一篇已经说过了,这里就不赘述了,宏哥直接填写了,有不明白的可以看看上一篇文章。如下图所示:

3.5 添加 JDBC 请求

通过上边的操作,我们已经定义了用户并且已经知道目的地和接头人建立了联系之后,然后我们就需要给这些用户分配具体的任务了(谁负责监视,谁负责刺杀,谁负责放哨)。在本部分中,你将指定要执行的 JDBC 请求(刺杀任务)。这里就开始执行刺杀任务,期间有核查组员的人物背景、其他组员支援、以及自己组员的牺牲、任务的变更等等

3.5.1 查询(核查组员信息)

3.5.2 插入(其他组员支援)

3.5.3 修改(组员档案变更)

3.5.4 删除(自己组员牺牲)

3.6 添加监听器以查看/存储测试结果(监听器 - 查看任务是否成功)

您需要添加到测试计划中的最后一个元素是 Listener。该元素负责将 JDBC 请求的所有结果存储在文件中并显示结果。如下图所示:

3.7 保存与执行测试计划

保存与执行测试计划,查看任务结果,如下图所示:

宏哥为了让小伙伴们看得清楚,讲后边的三个请求都修改成 disable 了,修改后由黑色变成了灰色。然后慢慢的逐个再将其修改成 enable。如下图所示:

3.7.1 核查人员信息情况

1、首先查询 MySQL 数据,如下图所示:

2、看一下 JMeter 执行后与上边的查询结果一致,说明核查人员信息成功。如下图所示:

3.7.2 核查人员支援情况

1、首先查询 MySQL 数据,只有四个人员,如下图所示:

2、JMeter 执行后,北京宏哥前来支援,我们分别查看 MySQL 和 JMeter 的结果,如下图所示:

JMeter:

MySQL:

3.7.3 核查人员变更情况

1、首先查询 MySQL 数据,只有五个人员,如下图所示:

2、JMeter 执行后,将 “赵六” 变更成 “赵丽”,我们分别查看 MySQL 和 JMeter 的结果,如下图所示:

JMeter:

MySQL:

3.7.4 核查人员牺牲情况

1、首先查询 MySQL 数据,只有五个人员,如下图所示:

2、JMeter 执行后,李四在任务中牺牲,我们分别查看 MySQL 和 JMeter 的结果,如下图所示:

JMeter:

MySQL:

4.小结

1、Cannot load JDBC driver class 'com.mysql.jdbc.Driver'

原因:未在 jmeter 安装目录下的./lib 目录下放入 mysql-connector-java-X.X.X-bin.jar

解决方法:将 mysql-connector-java-X.X.X-bin.jar 放入到./lib 目录,并重启 jmeter

2、CLIENT_PLUGIN_AUTH is required

原因:导入的 mysql-connector-java-X.X.X-bin.jar 版本问题(原来导入 mysql-connector-java-8.0.17.jar),上网查资料,知驱动和 mysql 数据库的版本也有关系(参考 mysql-connector-java 之 6.0.6 版本,SQLNonTransientConnectionException: CLIENT_PLUGIN_AUTH is required 异常问题 - wenqi0501 的个人空间 - OSCHINA https://my.oschina.net/u/3640994/blog/3000068

mysql 官网驱动版本和数据库版本说明,地址:https://dev.mysql.com/doc/connector-j/8.0/en/connector-j-versions.html

解决方法:替换成 mysql-connector-java-5.1.47.jar 后问题解决
3、Variable Name must not be null in Insert

原因:未在 JDBC Request 的控制面板里填写绑定的连接池

解决办法:填写和 JDBC Connection Configuration 一样的连接池即可

4、以下是各数据库 Database URL、JDBC Driver class 填写方式

数据库名 Database URL Driver class
MySQL jdbc:mysql://host[:port]/dbname com.mysql.jdbc.Driver
PostgreSQL jdbc:postgresql:{dbname} org.postgresql.Driver
Oracle jdbc:oracle:thin:@//host:port/service OR jdbc:oracle:thin:@(description=(address=(host={mc-name})(protocol=tcp)(port={port-no}))(connect_data=(sid={sid}))) oracle.jdbc.OracleDriver
Ingress (2006) jdbc:ingres://host:port/db[;attr=value] ingres.jdbc.IngresDriver
Microsoft SQL Server (MS JDBC driver) jdbc:sqlserver://host:port;DatabaseName=dbname com.microsoft.sqlserver.jdbc.SQLServerDriver
Apache Derby jdbc:derby://server[:port]/databaseName[;URLAttributes=value[;…]] org.apache.derby.jdbc.ClientDriver

  好了今天的建立数据库测试计划实战就分享到这里。

暂无回复。
需要 登录 后方可回复, 如果你还没有账号请点击这里 注册