暂无图片
暂无图片
1
暂无图片
暂无图片
暂无图片

MySQL常用性能指标

原创 阎书利 2022-11-30
1875

这里给大家分享一些MySQL的常用性能指标,可以对此增加一些自定义指标到数据库的监控里,如zabbix或者prometheus,来更好的检测数据库的状态。
我的MySQSL版本是5.7.19。因为是自己的测试环境,所以截图的一些指标很低,仅为大家展示查看参数的显示情况。

mysql> select version();
+-----------+
| version() |
+-----------+
| 5.7.19    |
+-----------+
1 row in set (0.00 sec)

(1) QPS(每秒Query量)

QPS = Questions(or Queries) / seconds

mysql > show global status like 'Question%';

image.png

(2) TPS(每秒事务量)

TPS = (Com_commit + Com_rollback) / seconds

mysql > show global status like'Com_commit'; mysql > show global status like'Com_rollback';

image.png

(3)key Buffer 命中率

key_buffer_read_hits = (1-key_reads /key_read_requests) * 100%
key_buffer_write_hits = (1-key_writes /key_write_requests) * 100%

mysql>show global status like 'key%';

image.png

(4)InnoDB Buffer命中率

innodb_buffer_read_hits = (1 -innodb_buffer_pool_reads / innodb_buffer_pool_read_requests) * 100%

mysql> show status like'innodb_buffer_pool_read%';

image.png

(5)Query Cache命中率

Query_cache_hits = (Qcahce_hits /(Qcache_hits + Qcache_inserts )) * 100%;

mysql> show status like 'Qcache%';

image.png

(6)Table Cache状态量

mysql> show global status like 'open%';

比较 open_tables 与opend_tables 值

image.png

(7)Thread Cache 命中率

mysql> show global status like'Thread%'; mysql> show global status like'Connections';

Thread_cache_hits = (1 - Threads_created /connections ) * 100%

image.png

(8)锁状态

mysql> show global status like '%lock%';

Table_locks_waited/Table_locks_immediate=0.0% 如果这个比值比较大的话,说明表锁造成的阻塞比较严重,Innodb_row_lock_waits 和Innodb_row_lock_time_avg太大,说明锁争用比较严重,有可能是间隙锁造成的,可以查询information_schema数据库中相关表查看锁情况,或者通过设置InnoDB Monitors来进一步观察锁冲突的表、数据行等,分析原因。

image.png

(9)复制延时

mysql > show slave status

查看延时
当前SQL线程运行的延时=Read_Master_Log_Pos-Exec_Master_Log_Pos

红框:
     Master_Log_File: mysql-bin.003590    //当前IO线程正在读取的主服务器二进制文件的名称
     Read_Master_Log_Pos: 331275450      //当前IO线程正在读取的二进制日志的位置
     Relay_Log_File: relaylog.009253     //SQL线程当前正在读取和执行的中继日志文件的名称
     Relay_Log_Pos: 331275665           //当前中继日志里,SQL线程已读取和执行的位置
     Relay_Master_Log_File: mysql-bin.003590     //由SQL线程执行的包含多数近期事件的主服务器二进制日志文件的名称

黄框:
     Slave_IO_Running: Yes         //IO线程是否被启动并成功的连接到主服务器上
     Slave_SQL_Running: Yes        //SQL线程是否被启动

蓝框:
     Last_Errno: 0                //是记录系统的最后一次错误代码
绿框:
     Exec_Master_Log_Pos: 331275450      //是SQL线程执行中继日志中相对于主库bin log的位点。Read_Master_Log_Pos减去Exec_Master_Log_Pos可以表示当前SQL线程运行的延时
     Relay_Log_Space: 331275954        //所有原有的中继日志结合起来的总大小

image.png

(10) Tmp Table 状况(临时表状况)

mysql > show status like 'Created_tmp%';

Created_tmp_disk_tables/Created_tmp_tables比值最好不要超过10%,如果Created_tmp_tables值比较大,可能是排序句子过多等原因。
image.png

(11) Binlog Cache 使用状况

mysql > show status like'Binlog_cache%';

如果Binlog_cache_disk_use值不为0 ,可能需要调大 binlog_cache_size大小
image.png

(12) Innodb_log_waits 量

mysql > show status like'innodb_log_waits';

Innodb_log_waits是等待日志缓冲刷出的次数,如果值不等于0的话,并且持续增长,表明 innodb log buffer 因为空间不足而等待,可以考虑增大innodb_log_buffer_size。

image.png

(13)open file and table

mysql> show global status like 'Open_files'; mysql> show global status like 'Open_tables';

image.png

(14) 慢查询

开启慢查询:

编辑/etc/my.cnf,在[mysqld]域中添加:
         slow_query_log= 1   # 开启慢查询
         slow_query_log_file=/data/mysql/slow.log   # 慢查询日志路径
         long_query_time= 1        # 慢查询的时长

查看慢查询数量:

[mysql@mogdb-kernel-0005 ~]$ mysqladmin -u root -pmysql status

image.png

(15)通用查询日志

查看通用查询日志状态:

mysql> show global variables like 'general_log';

image.png
开启通用查询日志:

mysql> set global general_log=on;

注意开启通用查询日志会消耗服务器性能,一般只有在排查问题时才会短暂打开。

最后修改时间:2022-11-30 17:12:31
「喜欢这篇文章,您的关注和赞赏是给作者最好的鼓励」
关注作者
【版权声明】本文为墨天轮用户原创内容,转载时必须标注文章的来源(墨天轮),文章链接,文章作者等基本信息,否则作者和墨天轮有权追究责任。如果您发现墨天轮中有涉嫌抄袭或者侵权的内容,欢迎发送邮件至:contact@modb.pro进行举报,并提供相关证据,一经查实,墨天轮将立刻删除相关内容。

文章被以下合辑收录

评论