news 2026/4/15 12:26:58

每周读书与学习-amp;gt;JMeter性能测试脚本编写实战(三)如何利用JMeter为MySQL数据库构造测试数据

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
每周读书与学习-amp;gt;JMeter性能测试脚本编写实战(三)如何利用JMeter为MySQL数据库构造测试数据

每周读书与学习是由清华大学出版社出版的《JMeter核心技术、性能测试与性能分析》一书的作者推出,分享作者多年的IT从业经历,希望对很多计算机科学技术IT类专业毕业生以及IT从业者有所帮助。

在前面的学习中,介绍了很多Jmeter的理论知识,包括Jmeter中很多不同元件的详细介绍以及每个元件的作用,本次主要从实践的角度来介绍怎么用这些元件来完成常见性能测试脚本的编写,将会介绍一些常见的性能测试脚本编写案例。

在上一次分享中,分享了前一个请求返回的结果作为后一个请求的入参的案例,本次将分享如何利用JMeter为MySQL数据库构造测试数据

1、如何利用JMeter为MySQL数据库构造测试数据

在性能压测中,经常需要构造大量的数据以在测试环境中模拟出类似生产环境中同等的数据量,以便让性能压测更加贴近真实的生产环境,JMeter不但是一个很好的性能测试工具,而且还可以用其来构造性能测试数据,如下示例将演示如何使用JMeter给指定的表中插入10万条数据。

首先在MySQL数据库中创建两张表,其建表语句分别如下所示:

create table jmeter_test_one

(

id bigint(20) NOT NULL AUTO_INCREMENT,

user_id varchar(11),

user_name varchar(25),

PRIMARY KEY (id)

);

create table jmeter_test_two

(

id bigint(20) NOT NULL AUTO_INCREMENT,

user_id varchar(11),

address varchar(25),

PRIMARY KEY (id)

);

在MySQL数据据中创建成功后,如下图所示。

MySQL数据库服务器的配置信息如下表所示。

服务器类型

配置说明

数据库服务器

内存:2GB

CPU:2核

部署软件:MySQL

操作系统:CentOS 7

由于JMeter 直接连接MySQL数据库,需要jdbc driver,所以需要先从MySQL的官网https://www.mysql.com/products/connector/ 下载jdbc driver,如下图所示。

启动JMeter,在JMeter的测试计划界面中,添加下载好的MySQL jdbc driver,如下图所示,通过点击浏览按钮,选择下载好的MySQL jdbc driver的路径,就可以将driver 添加进来了。

在测试计划中,添加一个Thread Group(线程组),然后在线程组下添加一个JMeter 的计数器元件,这里我们使用计数器来作为插入时的变量引用,引用名称设置为id,如下图所示,在计数器中做如下设置:

  • Starting value:表示起始值,这里设置构造数据的起始值为1。
  • 递增:表示构造数据时,每次递增多少,这里设置为1。
  • Maximum:表示数据的最大值设置为多大,通常可以设置为一个无穷大的数据即可,这里设置为100000000。
  • 数字格式:表示数字的格式,比如0001或者00001类似这样,也可以为空,这里不做任何的设置。
  • 引用名称:设置定义的计数器变量的名称,可以在jmeter的其他元件中作为参数引入使用。

在线程组下添加JDBC Connection Configuration 元件,并且在JDBC Connection Configuration的配置界面,配置MySQL JDBC的连接信息,如下图所示,相关的配置信息如下:

  • Variable name for created pool:设置创建的连接池的变量名称,这里设置为testpool。
  • Max number of connection:设置最大连接数,这里设置为10。
  • Max wait:设置最大等待时长(单位为毫秒),这里设置为10000。
  • Time between Eviction Runs:设置线程可空闲时长(单位为毫秒),这里设置为60000。
  • Auto commit:设置数据库事务是否自动提交,这里设置为True,表示开启数据库事务自动提交模式。
  • Transaction isolation:设置数据库事务隔离级别,这里选择DEFAULT。
  • Database url:以JDBC协议的格式输入目标数据库的URL地址。
  • Jdbc driver class:设置jdbc的驱动名称,在这里选择com.mysql.jdbc.Driver。
  • Username:设置连接目标数据库的用户名。
  • Password:设置连接目标数据库的密码。
  • Connection Properties:用于设置建立Mysql JDBC连接时需要自定义指定的连接属性。

在Thread Group 下添加JDBC Request取样器元件,如下图所示。

在JDBC Request 取样器中,配置我们的数据库插入操作,如下图所示,在中间的输入框中输入insert into jmeter_test_one(user_id,user_name) values('user_${id}','user_name_${id}');插入语句,其中${id}就是引用的计数器中定义的id变量。在variable name of pool declared in JdBC Connection Configuration中输入我们在JDBC Connection Configuration中定义的连接池名称testpool,并且将Query Type选择为Update Statement。如果是一次执行多条SQL语句,需要将Query Type选择为Callable Statement,update和delete 语句的Query Type和insert 语句的Query Type是一样的。

我们再在线程组下添加一个查看结果树组件,用于查看jmeter 请求是否成功,如下图所示,查看结果树通常用于Jmeter性能测试脚本的调试。

以上jmeter元件都添加好了后,就可以让jmeter 运行起来了,如下图所示所示,当运行时,可以从Jmeter结果树中看到JDBC Request 取样器的运行日志。

执行完成后,可以看到jmeter_test_one这张表已经插入超过10万条左右的数据,如下图所示。

使用同样类似的方式,再向jmeter_test_two表中也插入10万条数据,为接下来后面的MySQL数据库查询的性能压测做数据准备。

针对使用Jmeter构造数据总结如下:

l 合理使用Jmeter中的计数器元件,可以做到构造数据时的唯一性,避免重复数据。

l 合理使用好Jmeter中函数,可以构造出很多自己想要的数据格式,比如日期时间格式、IP地址、UUID等,如下图所示。

2、本次学习总结

读者们需要在做性能测试时,如果需要构造测试数据,知道如何借助JMeter来为数据库构造测试数据。

出处:本次学习的内容参考自清华大学出版社出版的《JMeter核心技术、性能测试与性能分析》一书

作者的原创文章,转载须注明出处。原创文章归作者所有,欢迎转载,但是保留版权。对于转载了博主的原创文章,不标注出处的,作者将依法追究版权,请尊重作者的成果。
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/14 15:38:43

存储空间规划:合理管理海量输出视频

存储空间规划:合理管理海量输出视频 引言:从生成到存储的工程挑战 随着 AIGC 技术的快速发展,Image-to-Video 图像转视频生成器已成为内容创作领域的重要工具。由科哥主导二次开发的这一版本,基于 I2VGen-XL 模型构建,…

作者头像 李华
网站建设 2026/3/26 22:02:07

3D GS编辑

GitHub - sparkjsdev/spark: :sparkles: An advanced 3D Gaussian Splatting renderer for THREE.js

作者头像 李华
网站建设 2026/3/27 15:41:26

大场景3DGS

Horizon-GS: Unified 3D Gaussian Splatting for Large-Scale Aerial-to-Ground Scenes GitHub - InternRobotics/HorizonGS: [CVPR 2025] Horizon-GS: Unified 3D Gaussian Splatting for Large-Scale Aerial-to-Ground Scenes

作者头像 李华
网站建设 2026/4/8 23:42:50

Sambert-HifiGan性能测评:中文情感语音合成的速度与质量

Sambert-HifiGan性能测评:中文情感语音合成的速度与质量 引言:为何需要高质量的中文多情感语音合成? 随着智能客服、虚拟主播、有声读物等应用场景的快速发展,传统“机械式”语音合成已无法满足用户对自然度和表现力的需求。尤其是…

作者头像 李华
网站建设 2026/3/27 8:34:17

Sambert-HifiGan在金融行业的应用:智能客服系统搭建

Sambert-HifiGan在金融行业的应用:智能客服系统搭建 引言:语音合成如何重塑金融服务体验 在数字化转型浪潮下,金融行业对智能化服务的需求日益增长。传统客服系统依赖人工坐席或机械式TTS(文本转语音)播报,…

作者头像 李华
网站建设 2026/4/15 1:26:00

最适合创业团队的AI镜像:轻量级部署方案TOP5

最适合创业团队的AI镜像:轻量级部署方案TOP5 Image-to-Video图像转视频生成器 二次构建开发by科哥 在当前AIGC快速发展的背景下,图像转视频(Image-to-Video, I2V) 技术正成为内容创作、广告设计、短视频生产等领域的关键工具。然而…

作者头像 李华