博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
计算 TPS,QPS 的方式
阅读量:6088 次
发布时间:2019-06-20

本文共 3051 字,大约阅读时间需要 10 分钟。

 

 

  在做db基准测试的时候,qps,tps 是衡量数据库性能的关键指标。本文比较了网上的两种计算方式。先来了解一下相关概念。

概念介绍:
QPS:Queries Per Second         查询量/秒,是一台服务器每秒能够相应的查询次数,是对一个特定的查询服务器在规定时间内所处理查询量多少的衡量标准。
TPS :  Transactions Per Second   是事务数/秒,是一台数据库服务器在单位时间内处理的事务的个数。 
 
如何计算:
从网上查看如果获取mysql 的qps,tps 的方法有如下两种:
方法一 基于 questions  计算qps,基于  com_commit  com_rollback 计算tps
questions = show global status like 'questions';
uptime = show global status like 'uptime';
qps=questions/uptime
 
PXC的node1的8.14的788.92948321500136061153303812186 = 765381516 / 970152   (如下图所示)
         node2的8.15的71.044197726791514945581117788519 = 251316505 / 3537467
         node3的8.16的55.369125506284308377917300126499 = 152671726 / 2757344
 
com_commit = show global status like 'com_commit';
com_rollback = show global status like 'com_rollback';
uptime = show global status like 'uptime';
tps=(com_commit + com_rollback)/uptime
PXC的node1的8.14的 74.122630741845631500008240897928  =   (71697100 + 258778)   /  970768    (如下图所示)
         node2的8.15的 8.3475571426471768700176484487794  =   (29498692 + 34865)    /   3537988
         node3的8.16的 9.2374227285203506490822419815147  =   (25475622 + 922)  / 2757971
 
方法二  基于 com_* 的status 变量计算tps ,qps
使用如下命令:
show global status where variable_name in('com_select','com_insert','com_delete','com_update');
获取间隔1s 的 com_*的值,并作差值运算
del_diff = (int(mystat2['com_delete'])   - int(mystat1['com_delete']) ) / diff
ins_diff = (int(mystat2['com_insert'])    - int(mystat1['com_insert']) ) / diff
sel_diff = (int(mystat2['com_select'])    - int(mystat1['com_select']) ) / diff
upd_diff = (int(mystat2['com_update'])   - int(mystat1['com_update']) ) / diff
PXC的node1(8.14)的信息==>
 
PXC的node2(8.15)的信息==>
mysql> show global status where variable_name in('com_select','com_insert','com_delete','com_update');
+---------------+-----------+
| Variable_name | Value     |
+---------------+-----------+
| Com_delete    | 147054    |
| Com_insert    | 44422198  |
| Com_select    | 106831065 |
| Com_update    | 3025968   |
+---------------+-----------+
4 rows in set (0.00 sec)
PXC的node3(8.16)的信息==>
mysql> show global status where variable_name in('com_select','com_insert','com_delete','com_update');
+---------------+----------+
| Variable_name | Value    |
+---------------+----------+
| Com_delete    | 132461   |
| Com_insert    | 43158855 |
| Com_select    | 21509316 |
| Com_update    | 2564956  |
+---------------+----------+
4 rows in set (0.00 sec)
上述计算方法的值准确合适吗?
下图是我手工做测试的结果:
a 针对mysql innodb 表的dml 操作做了各个量的统计,结果如下:
由上图可以得出结论:
1 com_commit, com_rollback 与显示指定transaction无关,只和显式提交commit rollback 有关。
2 不管dml的结果是否成功,com_* 都会增加1 。
 
b 针对myisam 表的测试:
1 对于myisam 表 进行dml操作 只有questions 改变其他值不变。
2 对于myisam 存储引擎使用com_* 计算其tps,qps 是不准确的,使用questions 的值计算相对比较合适。
 
利用脚本使用不同的变量获取数据库的qps,tps 的对比图:
qps_s      是基于 com_select
qps_ques 是基于 questions ,
tps_iud    是基于 com_insert, com_update,com_delete 之和,
tps_com_rol是基于 com_commit com_rollback 之和
由上图可以查看 基于questions 要比基于com_select的数值要大,因为questions本身是所有db访问的集合。
 
总结:
Questions 是记录了从mysqld启动以来所有的select,dml 次数包括show 命令的查询的次数。这样多少有失准确性,比如很多数据库有监控系统在运行,每5秒对数据库进行一次show 查询来获取当前数据库的状态,而这些查询就被记录到QPS,TPS统计中,造成一定的"数据污染".
如果数据库中存在比较多的myisam表,则计算还是questions 比较合适。
如果数据库中存在比较多的innodb表,则计算以com_*数据来源比较合适。
 

转载地址:http://njvwa.baihongyu.com/

你可能感兴趣的文章
Struts2与Struts1区别
查看>>
网站内容禁止复制解决办法
查看>>
Qt多线程
查看>>
我的友情链接
查看>>
想说一点东西。。。。
查看>>
css知多少(8)——float上篇
查看>>
NLB网路负载均衡管理器详解
查看>>
水平添加滚动条
查看>>
PHP中”单例模式“实例讲解
查看>>
VM EBS R12迁移,启动APTier . AutoConfig错误
查看>>
atitit.细节决定成败的适合情形与缺点
查看>>
Mysql利用binlog恢复数据
查看>>
我的友情链接
查看>>
用yum安装mariadb
查看>>
一点IT"边缘化"的人的思考
查看>>
WPF 降低.net framework到4.0
查看>>
搭建一个通用的脚手架
查看>>
开年巨制!千人千面回放技术让你“看到”Flutter用户侧问题
查看>>
开源磁盘加密软件VeraCrypt教程
查看>>
本地vs云:大数据厮杀的最终幸存者会是谁?
查看>>