1、为什么要使用JMeter连接数据库

我们测试的软件项目中,所有的数据都是存储在数据库。我们可以直接使用JMeter链接数据库,把需要的数据取出来,和通过接口方式取出来的返回数据进行比对,如果数据一致,说明后台程序开发的没有问题。

2、JMeter连接数据库的前提

由于JMeter本身没有提供链接数据库的功能,所以我们需要借助三方的工具包来实现。

也就是下载JMeter链接MySQL数据库的JAR包:mysql-connector-java.jar

需要根据自己MySQL的版本下载对应驱动,尽量保证其版本和你数据库的版本一致,至少不低于数据库版本,否则可能有问题。

MySQL各版本驱动JAR包下载地址:https://repo1.maven.org/maven2/mysql/mysql-connector-java/

最后将下载好的MySQL驱动,放在JMeter的bin目录下。(因为方便找到,也可以放在lib目录下,或者公司规范的目录中。)

提示

(1)驱动放哪?

  1. 随便放:需要在测试计划界面中进行引入。
  2. 认真放:放到JMeter的安装路径的lib目录下,就不需要再次引入了,需要重启一次JMeter。

(2)mysql-connector-java与MySQL对应版本

官方推荐mysql-connector-java.jar8.0版本,与MySQL Server8.05.75.6版本一起使用。

(我的Mysql版本为5.7.30,用mysql-connector-java5.1和在8.0版本都可以,亲测。)

(3)mysql-connector-java与Java对应版本

官方提示:JRE 1.7需要使用mysql-connector-java5.1.21及更高版本。

3、JDBC连接配置组件界面介绍

添加JDBC连接配置组件的操作:选中“线程组”右键 —> 添加 —> 配置元件 —> JDBC Connection Configuration

JDBC连接配置界面,如下图所示:

界面详细说明:

  • 名称JDBC Connection Configuration组件的自定义名称,见名知意最好。
  • 注释:即添加一些备注信息,对该JDBC连接配置组件的简短说明,以便后期回顾时查看。

1)Variable Name Bound to Pool:绑定一个数据库的链接。

Variable Name for created pool:定义数据库连接池的名称。(自定义填写,一般与数据库同名)

2)Connection pool Configuration:数据库连接池配置,一般都保持默认,可根据特定需要进行修改。

  1. Max Number of Connections:对该数据库的最大连接数。通常该值设置为0,意思是每个线程都使用单独的数据库连接,例如,配置在两个线程间不共享。如果你确实想共享连接池,那么最大连接数应当和线程数一样,以便线程不用互相等待,做性能测试时用。
  2. Max Wait(ms):在连接池中取回连接最大等待时间,单位毫秒。如果超过改时间,将抛出一个错误。
  3. Time Between Eviction Runs(ms):数据库空闲连接的回收时间间隔,单位毫秒。超过设置的空间时间后,该链接任然没有使用,则会将该空闲链接物理性的关闭掉。次选项若为非正数,则空闲连接回收器不停运行。
  4. Auto Commit: 自动提交SQL语句。此处有三个选项true、false、编辑,如:选择True后, 每条SQL语句就是一个事务,执行结束后会自动提交到数据库。否则不会提交,需要自己手动提交。
  5. Transaction isolation:数据库的事务隔离级别设置,JDBC定义了五种事务隔离级别:
    • TRANSACTION NONE:不支持事务。
    • TRANSACTION READ UNCOMMITTED:事务读取未提交内容,允许脏读,不可重复读和幻读。
    • TRANSACTION READ COMMITTED:事务读取已提交读内容,禁止脏读,但允许不可重复读和幻读。
    • TRANSACTION SERIALIZABLE:事务序列化。一个事务读时,其他事务只能读,不能写。禁止脏读、不可重复读和幻读。
    • TRANSACTION REPEATABLE READ:事务重复读。两个事务同时进行时,其中一个事务修改数据对另一个事务不会造成影响,即使修改的事务已经提交也不会对另一个事务造成影响。禁止脏读,不可重复读,但允许幻读。
    • DEFAULT:使用相应数据库对应的默认事务隔离级别,例如大多数的数据库系统中,默认事务隔离级别都是Read committed,而MySQL的默认事务隔离级别是Repeatable Read

拓展一点:

  • 脏读(dirty read):一个事务读取了另一个事务尚未提交的数据。
  • 不可重复读(Non-Repeatable Reads):一个事务的操作导致另一个事务前后两次读取到不同的数据。
  • 幻读(Phantom Reads):一个事务的操作导致另一个事务前后两次查询的结果数据量不同。

3)Connection Validation by Pool:连接池有效性验证配置,这是JMeter用来检验数据库连接是否有效的一种机制。

  1. Test While Idle:是否对空闲连接进行有效性验证(当连接空闲时是否断开)。当连接空闲时,是否使用Validation Query去测试连接。
  2. Soft Min Evictable Idle Time(ms):连接在连接池中闲置的最小时间,超出此闲置时间连接才会被回收,默认值为5000ms。额外的条件是,在连接池中至要保留有minIdle个连接。
  3. Validation Query:用于验证数据库是否仍在响应的简单查询语句。默认是JDBC驱动的 isValid() 方法,它适合于很多数据库。可以通过jmeter.propertiesjdbc.config.check.query属性设置默认的验证SQL语句。

说明:默认配置的意思:表示每隔5000ms执行一次Validation Query选中的SQL,来验证连接是否有效。默认Validation Query中填写任何内容,就表示不进行验证。

4)Database Connection Configuration:数据库连接配置。

  1. Database URL:数据库连接 URL 。例如:jdbc:mysql://127.0.0.1:3306/ecshop,表示本地数据库,3306端口,数据库名称为ecshop。(后边还可以加上来链接一些参数配置)
  2. JDBC Driver class:数据库驱动程序的完全名称,有下拉菜单可选。
  3. Username:数据库登录的用户名。
  4. Password:数据库登录的密码。

4、JMeter连接数据库演示

以JMeter连接MySQL数据库为例。

(1)测试计划内包含的元件

添加元件操作步骤

  1. 创建测试计划。
  2. 创建线程组:选中“测试计划”右键 —> 添加 —> 线程(用户) —> 线程组
  3. 在线程组中,添加配置元件JDBC Connection Configuration(JDBC连接配置)组件:选中“线程组”右键 —> 添加 —> 配置元件 —> JDBC Connection Configuration
  4. 在线程组中,添加取样器JDBC Request(JDBC请求)组件:选中“线程组”右键 —> 添加 —> 取样器 —> JDBC Request
  5. 在线程组中,添加监听器“察看结果树”组件:选中“线程组”右键 —> 添加 —> 监听器 —> 察看结果树

最终测试计划中的元件如下:

点击运行按钮,会提示你先保存该脚本,脚本保存完成后会直接自动运行该脚本。

(2)测试计划中添加链接数据库所依赖的JAR包

在测试计划中,点击添加目录或jar包到ClassPath 后的”浏览“按钮,选择mysql-connector-java.jar文件。

(如果放在JMeter的bin目录下,直接就能够看到,非常方便。放在lib\ext目录下,每次自动加载也可以。)

如下图所示:

(3)jdbc connection configuration组件内容

JDBC Connection Configuration(JDBC连接配置)组件,就相当于对一个数据库链接配置。

一个测试计划可以有多个JDBC连接配置组件,只要名称不重复就行,即Variable Name for created pool命名不重复。

编辑后的jdbc connection configuration组件界面,如下图所示:

我们把该数据库链接命名为ecshop4,输入数据库地址Database URL,选择数据库链接所需要的驱动,填写数据库的用户名密码即可。(也就是填写第一部分和第四部分的内容,其他内容默认即可)

(4)JDBC Request组件界面内容

在线程组下添加一个专门用于向数据库发送SQL语句的取样器JDBC Request组件。

操作方式:选中“线程组”右键 —> 添加 —> 取样器 —> JDBC Request

编辑界面中的内容:

  1. 编辑Variable Name of Pool declared in JDBC Connection Configuration的内容:填写数据库连接池的名称,也就是填写一个定义好的JDBC Connection Configuration组件中的Variable Name名称。例如我们上边定义的ecshop4
  2. Query Type:选择查询类型,我们只进行一条查询语句,所以选择Select Statement即可。
  3. Query:的输入框中编写要发送的SQL语句。

其他默认即可,这样我们就发送出一个最基础的JDBC请求了。

如下图所示:

提示:我们在这里不详解的介绍JDBC Request组件的说明和使用,在后面文章中,会详细进行说明。

(5)查看结果

运行该JMeter脚本后,会自动去目标数据库中进行查询操作,之后会把查询的结果返回到JMeter中。

如下图所示:

以上就是使用JMeter连接数据库的操作,我们以MySQL为例进行的演示,其他数据库同理,学会举一反三。

本篇文章主要说明的是:

  • JDBC连接配置JDBC Connection Configuration)组件的详细说明。
  • 还有一个是使用JMeter连接数据库的过程。
  • 关于JDBC Request组件详细说明,和各种用法,在后面的文章会详细介绍。

『动善时』JMeter基础 — 41、使用JMeter连接数据库(MySQL)的更多相关文章

  1. 『动善时』JMeter基础 — 6、使用JMeter发送一个最基础的请求

    目录 步骤1:创建一个测试计划 步骤2:创建线程组 步骤3:创建取样器 步骤4:创建监听器 步骤5:完善信息 步骤6:保存测试计划 步骤7:查看结果 总结:JMeter测试计划要素 当我们第一次打开J ...

  2. 『动善时』JMeter基础 — 2、JMeter的安装和启动

    1.安装Java环境 由于JMeter是纯Java的桌面应用程序,因此它的运行环境需要Java环境,即需要安装JDK或JRE.(也就是安装JDK环境) 步骤简要说明: 下载并安装JDK 配置环境变量 ...

  3. 『动善时』JMeter基础 — 7、jmeter.properties文件常用配置

    目录 1.默认语言设置 2.配置默认编码格式 3.GUI图标放大比例设置 4.功能区工具栏图标大小设置 5.视图区目录树图标大小设置 6.内容区编辑字体设置 7.添加JMeter元素快捷键设置 8.捕 ...

  4. 『动善时』JMeter基础 — 27、通过JMeter函数助手实现参数化

    目录 1.测试计划中的元件 2.数据文件内容 3.函数助手配置 (1)函数助手的打开方式 (2)函数助手界面介绍 (3)编辑后的函数助手界面 4.HTTP请求组件内容 5.线程组元件内容 6.脚本运行 ...

  5. 『动善时』JMeter基础 — 47、JMeter的HTTP代理服务器详细介绍

    目录 1.HTTP代理服务器的添加 2.HTTP代理服务器界面详解 (1)State:状态 (2)Global Settings:全局设置 (3)Test Plan Creation:测试计划创建 ( ...

  6. 『动善时』JMeter基础 — 21、HTTP Cookie管理器的使用

    目录 1.在HTTP信息头管理器组件中添加Cookie信息 (1)测试计划内包含的元件 (2)请求取样器内容 (3)HTTP信息头管理器内容 (4)查看结果 2.使用HTTP Cookie管理器组件来 ...

  7. 『动善时』JMeter基础 — 8、JMeter主要元件介绍

    目录 1.测试计划(Test Plan) 2.线程组 3.取样器(sampler) 4.逻辑控制器(Logic Controller) 5.配置元件(Config Element) 6.定时器(Tim ...

  8. 『动善时』JMeter基础 — 20、JMeter配置元件【HTTP Cookie管理器】详细介绍

    目录 1.HTTP Cookie管理器介绍 2.HTTP Cookie管理器界面详解 3.JMeter中对Cookie的管理 (1)Cookie的存储 (2)Cookie的管理策略 4.补充:Cook ...

  9. 『动善时』JMeter基础 — 37、将JMeter测试结果写入Excel

    目录 1.环境准备 (1)引入操作Excel文件的基础JAR包 (2)引入封装自定义操作Excel文件的JAR包 2.准备测试需要的数据 3.测试结果写入Excel演示 (1)测试计划内包含的元件 ( ...

随机推荐

  1. 初探SQL注入需要知道的5个问题

    SQL注入产生原理 可控变量(注入点,就是传参) 带入数据库查询 变量未存在过滤或过滤不严谨 例子: 获取admin表的pass里面的数据 select * from users where id=1 ...

  2. 脱离xml使用JavaConfig实现Spring配置

    总结 情况一: 配置类中类名添加 @Configuration 注解,同时提供一个方法返回一个Bean实例,且这个方法添加注解 @Bean ,就可以由Spring管理此对象 如下所示: User.ja ...

  3. Java安全之FastJson JdbcRowSetImpl 链分析

    Java安全之FastJson JdbcRowSetImpl 链分析 0x00 前言 续上文的Fastjson TemplatesImpl链分析,接着来学习JdbcRowSetImpl 利用链,Jdb ...

  4. 【Docker】7. 镜像-加载原理、分层原理、commit镜像

    一.什么是镜像 镜像是一种轻量级.可执行的独立软件包,用来打包软件运行环境和基于运行环境开发的软件. 它包含运行某个软件所需的所有内容,包括代码.运行时环境.库.环境变量和配置文件. 所有的应用,直接 ...

  5. .Net Core导入千万级数据至Mysql

    ​最近在工作中,涉及到一个数据迁移功能,从一个txt文本文件导入到MySQL功能. 数据迁移,在互联网企业可以说经常碰到,而且涉及到千万级.亿级的数据量是很常见的.大数据量迁移,这里面就涉及到一个问题 ...

  6. 关于Annotation注解的理解

    在编Java程序的时候,我们经常会碰到annotation.比如:@Override 我们在子类继承父类的时候,会经常用到这个annotation.它告诉编译器这个方法是override父类的方法的. ...

  7. table不能使用jQuery的slideDown的解决方法

    table不能使用jQuery的slideDown的解决方法 一个后台管理项目中遇到了如下场景 要求父级栏目可以收纳子栏目,即折叠功能,而且要有过渡动画,不能太生硬. 它是用table来实现的,但是遇 ...

  8. 绿色版 notepad++ 添加鼠标右键菜单

    建立一个后缀为 .reg 的注册文件,拷贝以下内容并替换相关路径,保存病双击文件运行加入注册表. Windows Registry Editor Version 5.00 [HKEY_CLASSES_ ...

  9. 029. Python多态介绍

    多态:不同的子类对象,调用相同的父类方法,产生不同的结果 继承 重写 在不改变原有代码的前提下,实现了不同的效果 class Soldier(): # 攻击 def attack(self): pas ...

  10. linux python3安装whl包时报错解决:is not a supported wheel on this platform

    原因1 你下载安装的包不是当前平台所支持的 原因2 你下载的包,不符合你所在的平台的安装whl的名称规范,所以出错.比如当前我要安装的包是:pymssql-2.1.5-cp36-cp36m-manyl ...