zoukankan      html  css  js  c++  java
  • MySQL-TPS,QPS到底是什么

    计算TPS,QPS的方式

    qps,tps是衡量数据库性能的关键指标,网上普遍有两种计算方式

    TPS,QPS相关概念

    QPS:Queries Per Second         查询量/秒,是一台服务器每秒能够相应的查询次数,是对一个特定的查询服务器在规定时间内所处理查询量多少的衡量标准

    TPS :  Transactions Per Second   是事务数/秒,是一台数据库服务器在单位时间内处理的事务的个数。

    计算方式一:基于 questions  计算qps,基于  com_commit  com_rollback 计算tps

    questions = show global status like 'questions';
    uptime = show global status like 'uptime';
    qps=questions/uptime
     
    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
    

    方法二  基于 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

    tps= Com_insert/s + Com_update/s + Com_delete/s

    qps=Com_select/s + Com_insert/s + Com_update/s + Com_delete/s

      

    一些结论

    总结

    Questions 是记录了从mysqld启动以来所有的select,dml 次数包括show 命令的查询的次数。这样多少有失准确性,比如很多数据库有监控系统在运行,每5秒对数据库进行一次show 查询来获取当前数据库的状态,而这些查询就被记录到QPS,TPS统计中,造成一定的"数据污染".

    如果数据库中存在比较多的myisam表,则计算还是questions 比较合适。
    如果数据库中存在比较多的innodb表,则计算以com_*数据来源比较合适。

      

  • 相关阅读:
    用stetho通过网页访问手机数据库
    Python学习笔记(一)
    Linux学习笔记(四)Linux常用命令
    Linux学习笔记(三)Shell命令机制
    Linux学习笔记(一)
    Linux学习笔记(五)Linux应用程序的安装和卸载
    Linux学习笔记(二)Shell教程
    Linux学习笔记(六)Linux服务程序的安装和卸载
    前端模块总结
    div+css命名规范
  • 原文地址:https://www.cnblogs.com/asea123/p/10572766.html
Copyright © 2011-2022 走看看