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

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

1.简介

  在实际工作中,我们经常会听到数据库的性能和稳定性等等,这些有时候也需要测试工程师去评估和测试,因此这篇文章宏哥主要介绍了 jmeter 连接和创建数据库测试计划的过程,宏哥在文中通过示例和代码非常详细地介绍给大家,希望对各位小伙伴和童鞋们的学习或者工作具有一定的指导和参考学习价值,遇到类似的问题脑子一片空白的童鞋们可以参考一下。

2.建立数据库测试计划

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

2.1 新建测试计划

首先启动 JMeter 我们新建一个测试计划,如下图所示:

2.2 添加用户

新建完测试计划以后,我们前边也讲过了,这时候就要添加用户了。你要对每个 JMeter 测试计划进行的第一步是添加一个线程组(用户)。线程组告诉 JMeter 您要模拟的用户数量,用户应多久发送一次请求以及应发送多少次请求。

添加用户的步骤: 首先选择 “ 测试计划 ” 来添加ThreadGroup元件,单击鼠标右键以获得 “ 添加” 菜单,然后选择 “ 添加” →“ ThreadGroup ”。

添加完用户以后,你应该在 “测试计划” 下可以看到 “线程组” 元素。如果没有看到该元素,则通过单击 “测试计划” 元素前边的 “ *+ * ” 来展开 “测试计划” 树,就可以看到你添加的用户了。

最后,你需要修改默认属性(如果需要修改,不需要修改默认即可)。如果尚未选择线程组元素,则在树中选择它。那么你就可以在 “ JMeter” 窗口的右侧部分中看到 “线程组控制面板”,如下图所示:

2.3 添加 JDBC 连接配置

通过上边的操作,我们已经定义了用户,然后我们必须定义这些用户所要去的目的地,和目的地建立联系。不要这些用户累死累活的干了半天的活,知不道是为谁干得活。在本部分中,你需要和目的地建立联系。

具体步骤: 首先选择ThreadGroup元件。单击鼠标右键获得 “ 添加” 菜单,然后选择 “ *添加” →“ *配置元素” →“ **JDBC 连接配置”。然后,选择此新元件以查看其控制面板。我们需要设置一些字段,这些字段相当于谍战片中的接头暗号,例如:《智取威虎山》杨子荣与坐山雕的接头暗号:脸红什么?精神焕发。怎么又黄拉?度 ** 防冷涂的蜡;长江长江我是黄河,等等。暗号对上了,才可以建立联系。否则认为有危险,不是建立联系,具体在测试中的表现就是报错了!!!

设置以下字段(这些假设我们将使用名为 “hongge ” 的 MySQL 数据库):

  • Variable Name(绑定到池的变量名称):该名称自定义,在 JDBC Request 会用到;这需要唯一地标识配置。JDBC Sampler 使用它来标识要使用的配置。
  • Database URL(数据库 URL):jdbc:mysql:// 数据库 IP 地址:数据库端口/数据库名称(例如宏哥本地搭建 MySQL:jdbc:mysql://localhost:3306 / hongge)
  • JDBC Driver Class(JDBC 驱动程序类):com.mysql.jdbc.Driver
  • Username(用户名) 数据库连接的用户名
  • Password(密码):数据库连接的密码

注意:敲脑壳,敲黑板啦!!!

JMeter 使用 “控制面板” 中指定的配置设置创建数据库连接池。在 “ 变量名 ” 字段的 JDBC 请求中引用该池。可以使用几种不同的 JDBC Configuration 元素,但是它们必须具有唯一的名称。每个 JDBC 请求必须引用一个 JDBC 配置池。一个以上的 JDBC 请求可以引用同一个池。

连接配置的控制面板的其他字段可以保留为默认值。如下图所示:

2.4 添加 JDBC 请求

通过上边的操作,我们已经定义了用户并且已经知道目的地和接头人建立了联系之后,然后我们就需要给这些用户分配具体的任务了(谁负责监视,谁负责刺杀,谁负责放哨)。在本部分中,你将指定要执行的 JDBC 请求(刺杀任务)。

具体步骤: 选择ThreadGroup元件。单击鼠标右键获得 “ 添加” 菜单,然后选择 “ 添加” →“ ** 采样器” →“ **JDBC 请求”。然后,选择此新元素以查看其控制面板。

JMeter 按照将请求添加到树中的顺序发送请求。

首先编辑以下属性

  • Variable name: 这里写入数据库连接池的名字(和 JDBC Connection Configuration 名字保持一致 )
  • Query: 里面填入查询数据库数据的 SQL 语句(填写的 SQL 语句末尾不要加 “;”)
  • parameter valus: 数据的参数值
  • parameter types: 数据的参数类型
  • cariable names: 保存 SQL 语句返回结果的变量名
  • result cariable name: 创建一个对象变量,保存所有返回结果
  • query timeout: 查询超时时间
  • handle result set: 定义如何处理由 callable statements 语句返回的结果

如下图所示:

其中 Query Type(SQL 语句类型)包含十个类型,每个类型作用都不同,下面分别介绍。

1、Select statement

这是一个查询语句类型;如果 JDBC Request 中的 Query 内容为一条查询语句,则选择这种类型。

PS: 多个查询语句 (不使用参数的情况下) 可以放在一起顺序执行,需要设置 Query Type 为:Callable Statement;

如果Query Type为:select Statement,则只执行第一条select语句。

2、Update statement

这是一个更新语句类型(包含 insert 和 update);如果 JDBC Request 中的 Query 内容为一条更新语句,则选择这种类型。

PS: 如果该类型下写入多条 update 语句,依然只执行第一条(原因同上,具体下面介绍)。

3、Callable statement

这是一个可调用语句类型,CallableStatement 为所有的 DBMS 提供了一种以标准形式调用已储存过程的方法。

已储存过程储存在数据库中,对已储存过程的调用是 CallableStatement 对象所含的内容。

这种调用是用一种换码语法来写的,有两种形式:一种形式带结果参数,另一种形式不带结果参数;结果参数是一种输出 (OUT) 参数,是已储存过程的返回值。

两种形式都可带有数量可变的输入(IN 参数)、输出(OUT 参数)或输入和输出(INOUT 参数)的参数,问号将用作参数的占位符。

在 JDBC 中调用已储存过程的语法如下所示。注意,方括号表示其间的内容是可选项;方括号本身并不是语法的组成部份。

{call 过程名 [(?, ?, ...)]},返回结果参数的过程的语法为: {? = call 过程名 [(?, ?, ...)]};

不带参数的已储存过程的语法类似:{call 过程名}。

更详细的使用方法可参考这篇文章:http://blog.csdn.net/imust_can/article/details/6989954

4、Prepared select statement

statement 用于为一条 SQL 语句生成执行计划(这也是为什么 select statement 只会执行第一条 select 语句的原因),如果只执行一次 SQL 语句,statement 是最好的类型;

Prepared statement 用于绑定变量重用执行计划,对于多次执行的 SQL 语句,Prepared statement 无疑是最好的类型(生成执行计划极为消耗资源,两种实现速度差距可能成百上千倍);

PS: PreparedStatement 的第一次执行消耗是很高的. 它的性能体现在后面的重复执行。

更详细的解释请参考这一篇文章:http://blog.csdn.net/jiangwei0910410003/article/details/26143977

5、Prepared update statement

Prepared update statement 和 Prepared select statement 的用法是极为相似的,具体可以参照第四种类型。

6、Commit

commit 的意思是:将未存储的 SQL 语句结果写入数据库表;而在 jmeter 的 JDBC 请求中,同样可以根据具体使用情况,选择这种 Query 类型。

7、Rollback

rollback 指的是:撤销指定 SQL 语句的过程;在 jmeter 的 JDBC 请求中,同样可以根据需要使用这种类型。

8、AutoCommit(false)

MySQL 默认操作模式就是 autocommit 自动提交模式。表示除非显式地开始一个事务,否则每条 SQL 语句都被当做一个单独的事务自动执行;

我们可以通过设置 autocommit 的值改变是否是自动提交 autocommit 模式;

而 AutoCommit(false) 的意思是 AutoCommit(假),即将用户操作一直处于某个事务中,直到执行一条 commit 提交或 rollback 语句才会结束当前事务重新开始一个新的事务。

9、AutoCommit(true)

这个选项的作用和上面一项作用相反,即:无论何种情况,都自动提交将结果写入,结束当前事务开始下一个事务。

10、编辑(${})

jmeter 中的 JDBC 请求中的 SQL 语句是无法使用参数的,比如: SELECT * FROM ${table_name} 是无效的。

如果需实现同时多个不同用户使用不同的 SQL,可以通过把整条 SQL 语句参数化来实现;(把 SQL 语句放在 csv 文件中,然后在 JDBC Request 的 Query 中使用参数代替 ${SQL_Statement})。

备注: 后面的七项项涉及到数据库的事务控制等知识点,如果有不明白的地方请自行查询相关知识。

2.5 添加侦听器以查看/存储测试结果

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

具体步骤: 选择ThreadGroup元件并添加一个结果树的侦听器(添加 → 侦听器 → 结果树)。

侦听器显示结果及控制面板。如下图所示:

2.6 保存测试

在菜单点击 “保存” 按钮图标,选择保存位置,点击 “Save” 保存测试计划,如下图所示:

2.7 运行测试

保存测试计划以后,在菜单运行 → 开始或 **Ctrl + **R 运行测试,如下图所示:

3.小结

好了今天的创建数据库测试计划就分享到这里,下一篇宏哥带着小伙伴和童鞋们实战一下,小试一下牛刀。

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