Mysql-数据库压力测试

安装软件

官方软件
安装插件提供了更多的监听器选项
数据库驱动

数据库测试

配置

这里以一个简单的案例进行,进行连接池为10,20,30的梯度压测:

sql 复制代码
select * from tb_order_item where id= '1410932957404114945';
  • 新建一个线程组
  • 新增一个连接池配置
  • 新建一个JdbcRequest

    还需要关注连接池的选择

    更多的参数:
  1. Variable Name:数据库连接池的名字,需要与JDBC Connection Configuration的Variable NameBound Pool名字保持一致
  2. Query Type:此处支持方式多样,可以用于添加或者筛选数据,根据需要和Query配合使用;
    update statement 更新
    select statemen 查询
    prepared select statement 预处理参数查询
    prepared update statement 预处理参数更新
  3. Query:填写的sql语句未尾可以不加";"
  4. Parameter valus:参数值,顺序替代Query中的?;此处对应Query中的"?",有几个"?"则此处要填写几个值,以","分隔;
  5. Parameter types:参数类型可参考:Javadoc for java.sql.TypesParameter types则必须和Parameter values一一对应,且类型必须正确;
  6. Variable names:保存sql语句返回结果的变量名 ,用于作为参数供调用
  7. Result variable name:创建一个对象变量,保存所有返回的结果 ,供调用;
  8. Query timeout:查询超时时间
  9. Handle result set:定义如何处理由callable statements语句返回的结果。
    例如:
  • 设置监听器

    配置完成以后运行就行了
结果

可以看到最大连接数30和20差距不会特别大,20和10之前的TPS还是有一些差距的,可以初步得出结论不是最大连接数越大越好,事实我测试的是云服务器,带宽也就10M所以可能还是被带宽卡主了,如果是生产环境就需要配置不同的连接参数来压测,从而得到一个合理值。

更多配置说明

1 在配置连接池的时候可以选用隔离级别,如果不选默认就是数据库的隔离级别

2 配置Jdbc Request的时候可以写带有参数的SQL

相关推荐
人道领域1 天前
【黑马点评日记】:用户签到功能详解——从Bitmap入门到避坑指南
java·数据库·redis·后端
Vect__1 天前
MySQL初识和基础操作
数据库·mysql
zhaoyong2221 天前
如何在 MySQL 中实现基于全字段唯一性的重复行计数更新
jvm·数据库·python
X56611 天前
为什么宝塔面板网站无法正常连接外部远程数据库_检查服务器安全组放行端口并开启IP授权
jvm·数据库·python
woxihuan1234561 天前
C#怎么使用CancellationToken C#如何用取消令牌优雅地取消异步任务和长时间操作【进阶】
jvm·数据库·python
yexuhgu1 天前
MySQL主从复制支持跨版本吗_不同版本间同步的注意事项
jvm·数据库·python
woxihuan1234561 天前
CSS怎样调整弹性项目排列顺序_使用order属性轻松控制DOM显示顺序
jvm·数据库·python
m0_748554811 天前
golang如何实现数据去重处理_golang数据去重处理实现步骤
jvm·数据库·python
神明9311 天前
mysql索引排序规则设置方法_mysqlCollation对索引影响
jvm·数据库·python
Project_Observer1 天前
使用Zoho Projects记录工时时间后自动更新项目预算。
开发语言·数据库·人工智能·深度学习·机器学习