当前位置:网站首页>How to stress the MySQL performance indicators TPS\QPS\IOPS?
How to stress the MySQL performance indicators TPS\QPS\IOPS?
2022-08-04 13:03:00 【IT Bond】
哈喽!大家好,我是【IT邦德】,江湖人称jeames007,10年DBA工作经验
一位上进心十足的【大数据领域博主】!
中国DBA联盟(ACDU)成员,目前从事DBA及程序编程
擅长主流数据Oracle、MySQL、PG 运维开发,备份恢复,安装迁移,性能优化、故障应急处理等.
如果有对【数据库】感兴趣的【小可爱】,欢迎关注【IT邦德】
️️️感谢各位大可爱小可爱!️️️
文章目录
前言
今天主要介绍MySQL数据库,Or three key performance indicators for all databasesTPS\QPS\IOPS️ 1. Overview of performance metrics
QPS(Queries Per Second)is the number of queries per second,For the database, the database executes every second SQL 数(含 insert、select、update、delete 等).
TPS(Transactions Per Second)is the number of transactions per second.TPS For a database, it is the number of transactions performed by the database per second,以 commit 成功次数为准.
IOPS 每秒磁盘进行的I/O操作次数
️ 2. 指标计算方式
2.1 TPS
适用innodb
Transactions Per Second(每秒传输的事物处理个数),即服务器每秒处理的事务数
一般的,评价系统性能均以每秒钟完成的技术交易的数量来衡量.系统整体处理能力取决于处理能力最低模块的TPS值
mysql> SHOW GLOBAL STATUS LIKE 'Com_commit';
+---------------+-------+
| Variable_name | Value |
+---------------+-------+
| Com_commit | 22402 |
+---------------+-------+
1 row in set (0.00 sec)
mysql> SHOW GLOBAL STATUS LIKE 'Com_rollback';
+---------------+-------+
| Variable_name | Value |
+---------------+-------+
| Com_rollback | 0 |
+---------------+-------+
1 row in set (0.00 sec)
mysql> SHOW GLOBAL STATUS LIKE 'Uptime'
-> ;
+---------------+-------+
| Variable_name | Value |
+---------------+-------+
| Uptime | 3319 |
+---------------+-------+
1 row in set (0.01 sec)
TPS=(Com_commit + Com_rollback)/Uptime
2.2 QPS
Applicable to bothInnoDB和MyISAM 引擎
每秒查询率QPS是对一个特定的查询服务器在规定时间内所处理流量多少的衡量标准
对应fetches/sec,即每秒的响应请求数,也即是最大吞吐能力
2.3 IOPS
IOPS (Input/Output Per Second)即每秒的输入输出量(或读写次数),是衡量磁盘性能的主要指标之一.IOPS是指单位时间内系统能处理的I/O请求数量,一般以每秒处理的I/O请求数量为单位,I/O请求通常为读或写数据操作请求.随机读写频繁的应用,如OLTP(Online Transaction Processing),IOPS是关键衡量指标.另一个重要指标是数据吞吐量(Throughput),指单位时间内可以成功传输的数据数量.对于大量顺序读写的应用,如VOD(Video On Demand),则更关注吞吐量指标.
IOPS可细分为如下几个指标:
Toatal IOPS,混合读写和顺序随机I/O负载情况下的磁盘IOPS,
这个与实际I/O情况最为相符,大多数应用关注此指标.
Random Read IOPS,100%随机读负载情况下的IOPS.
Random Write IOPS,100%随机写负载情况下的IOPS.
Sequential Read IOPS,100%顺序负载读情况下的IOPS.
Sequential Write IOPS,100%顺序写负载情况下的IOPS.
IOPS的测试benchmark工具主要有Iometer, IoZone, FIO等,可以综合用于测试磁盘在不同情形下的IOPS.对于应用系统,需要首先确定数据的负载特征,然后选择合理的IOPS指标进行测量和对比分析,据此选择合适的存储介质和软件系统.
理论上可以计算出磁盘的最大IOPS,即IOPS = 1000 ms/ (Tseek + Troatation),忽略数据传输时间.假设磁盘平均物理寻道时间为3ms, 磁盘转速为7200,10K,15K rpm,则磁盘IOPS理论最大值分别为,
IOPS = 1000 / (3 + 60000/7200/2) = 140
IOPS = 1000 / (3 + 60000/10000/2) = 167
IOPS = 1000 / (3 + 60000/15000/2) = 200
️ 3. mysqlslap
3.1 压测
mysqlslap 是 MySQL 自带的一个用于实现负载性能测试和压力测试的工具.它可以模拟多个客户端对数据库进行施压,并生成报告来了解数据库的性能状况.
mysqlslap 的运行过程主要分三步:
① 创建库、表,导入数据用于测试.此过程由单线程完成.
② 开始进行压力测试.该步骤可以使用多线程完成.
③ 清理测试数据.此过程由单线程完成.
[[email protected] ~]# mysqlslap --help
3.2 案例
mysqlslap -uroot -proot -h192.168.1.54 -P3306 \
--create-schema=mysqlslap --auto-generate-sql \
--auto-generate-sql-load-type=mixed \
--concurrency=100,200 --number-of-queries=1000 \
--iterations=10 --number-int-cols=7 \
--number-char-cols=13 --auto-generate-sql-add-autoincrement
Benchmark
#Average time to run all statements,单位秒
Average number of seconds to run all queries: 0.018 seconds
#运行所有语句的最小秒数
Minimum number of seconds to run all queries: 0.018 seconds
#运行所有语句的最大秒数
Maximum number of seconds to run all queries: 0.018 seconds
#客户端数量
Number of clients running queries: 1
#每个客户端运行查询的平均数
Average number of queries per client: 0
This statement indicates that the test concurrency is 100 和 200 的情况,进行 1000 次访问(This value is generally estimated as such:并发客户数×每客户查询次数).Such a test method iterates 10 次,The final display is the largest、
最小、平均值
其中:--debug-info,代表要额外输出 CPU 以及内存的相关信息.如果报错 Option 'debug-info' used, but is disabled 请取消 debug-info 参数
-number-int-cols=7 Indicates that it must be present in the generated table 7 个 int 类型的列
-number-char-cols=13 Indicates that it must be present in the generated table 13 个 char 类型的列
-concurrency 代表并发数量,多个可以用逗号隔开,concurrency=10,50,100, 并发连接线程数分别是 10、50、100 个并发.
--engines 代表要测试的引擎,可以有多个,用分隔符隔开.
--iterations 代表要运行这些测试多少次.
--auto-generate-sql 代表用系统自己生成的 SQL 脚本来测试.
--auto-generate-sql-load-type 代表要测试的是读还是写还是两者混合的(read,write,update,mixed)
--number-of-queries 代表总共要运行多少次查询.每个客户运行的查询数量可以用查询总数/并发数来计算.
--debug-info 代表要额外输出 CPU 以及内存的相关信息.
--number-int-cols :创建测试表的 int 型字段数量
--auto-generate-sql-add-autoincrement : 代表对生成的表自动添加 auto_increment 列,从 5.1.18 版本开始
--number-char-cols 创建测试表的 char 型字段数量.
--create-schema 测试的 schema,MySQL 中 schema 也就是 database.
--query 使用自定义脚本执行测试,例如可以调用自定义的一个存储过程或者 sql 语句来执行测试.
--only-print See what the statement does.
边栏推荐
猜你喜欢
【微信小程序】信息管理与信息系统专业社会实习制作项目--垃圾指纹
Cool and efficient data visualization big screen, it's really not that difficult to do!丨Geek Planet
跨链桥已成行业最大安全隐患 为什么和怎么办
Arduino框架下I2S控制ADC采样以及PWM输出示例解析
使用COLMAP初步三维重建
GeoAO:一种快速的环境光遮蔽方案
手搓一个“七夕限定”,用3D Engine 5分钟实现烟花绽放效果
Hit the interview!The latest interview booklet of Ali Jin, nine silver and ten is stable!
持续交付(四)Jenkins多线程任务执行
【解决方案 三十一】Navicat数据库结构同步
随机推荐
从零开始配置 vim(6)——缩写
Escape character is ‘^]’什么意思?怎么使用telnet
罗振宇的A股梦,咋这么难圆?
他是“中台”之父,凭一个概念为阿里狂赚百亿
一分钟认识 IndexedDB 数据库,太强大了!
03 多线程与高并发 - ReentrantLock 源码解析
DateTimeFormatter api
Launcher app prediction
代码越写越乱?那是因为你没用责任链!
ES 节点2G内存分析
到底什么是真正的HTAP?
TS---类型设置
搭建ros交叉编译环境(从x86到nvidia arm)
判断密码是否包含键盘连续字母
Ceres库运行,模板内报内存冲突问题。(已解决)
“蔚来杯“2022牛客暑期多校训练营5 B、C、F、G、H、K
Cool and efficient data visualization big screen, it's really not that difficult to do!丨Geek Planet
HDU1580 输出先手能取的方案数
[UML] Summary of Information System Analysis and Design Knowledge Points
Matlab记录