news 2026/6/11 8:54:53

每周读书与学习-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/6/10 11:25:59

3D GS转点云

https://github.com/Lewis-Stuart-11/3DGS-to-PC

作者头像 李华
网站建设 2026/6/5 23:15:25

生成视频模糊?输入图像选择与参数匹配技巧

生成视频模糊?输入图像选择与参数匹配技巧 引言:从静态到动态的视觉跃迁 在AI生成内容(AIGC)领域,Image-to-Video(I2V)技术正迅速成为连接静态图像与动态叙事的关键桥梁。基于 I2VGen-XL 模型构…

作者头像 李华
网站建设 2026/6/10 4:11:14

Top 8 Image-to-Video开源方案对比及使用建议

Top 8 Image-to-Video开源方案对比及使用建议 背景与需求:动态视觉内容的爆发式增长 近年来,随着AIGC(人工智能生成内容)技术的迅猛发展,图像转视频(Image-to-Video, I2V)成为多模态生成领域的…

作者头像 李华
网站建设 2026/6/9 10:44:20

用Sambert-HifiGan打造个性化语音祝福生成系统

用Sambert-HifiGan打造个性化语音祝福生成系统 🎯 业务场景与痛点分析 在节日祝福、客户关怀、智能客服等实际应用场景中,个性化语音内容的自动化生成需求日益增长。传统的录音制作方式成本高、效率低,难以满足大规模定制化需求;而…

作者头像 李华
网站建设 2026/6/1 1:45:43

【好物推荐】IDEA 小技巧:新建文件自动进 Git,省手还能跟 “cannot find symbol” 说再见!

有没有小伙伴和我一样,在IDEA里写代码时踩过这坑: 不光新建个类/文件后,总得右键点“Git > Add”手动加版本控制(真的费手);更糟的是——有时候忘了点add就提交代码,结果自己本地跑没问题,团队小伙伴拉取后触发构建,突然弹出“cannot find symbol”的异常,好不容易…

作者头像 李华
网站建设 2026/5/29 4:40:36

Sambert-HifiGan语音合成服务持续集成与交付

Sambert-HifiGan语音合成服务持续集成与交付 📌 项目背景与技术选型动机 随着智能客服、有声阅读、虚拟主播等应用场景的普及,高质量中文语音合成(Text-to-Speech, TTS)已成为AI服务的关键能力之一。传统TTS系统往往依赖复杂的声学…

作者头像 李华