一些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%';

MySQL常用性能指标_监控

(2) TPS(每秒事务量)

TPS = (Com_commit + Com_rollback) / seconds

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

MySQL常用性能指标_性能指标_02

(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%';

MySQL常用性能指标_性能指标_03

(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%';

MySQL常用性能指标_性能指标_04

(5)Query Cache命中率

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

mysql> show status like 'Qcache%';

MySQL常用性能指标_慢查询_05

(6)Table Cache状态量

mysql> show global  status like 'open%';

比较 open_tables 与opend_tables 值

MySQL常用性能指标_监控_06

(7)Thread Cache 命中率

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

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

MySQL常用性能指标_mysql_07

(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来进一步观察锁冲突的表、数据行等,分析原因。

MySQL常用性能指标_慢查询_08

(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        //所有原有的中继日志结合起来的总大小

MySQL常用性能指标_性能指标_09

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

mysql > show status like 'Created_tmp%';

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

MySQL常用性能指标_监控_10

(11) Binlog Cache 使用状况

mysql > show status like'Binlog_cache%';

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

MySQL常用性能指标_mysql_11

(12) Innodb_log_waits 量

mysql > show status like'innodb_log_waits';

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

MySQL常用性能指标_慢查询_12

(13)open file and table

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

MySQL常用性能指标_性能指标_13

(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

MySQL常用性能指标_监控_14

(15)通用查询日志

查看通用查询日志状态:

mysql> show global variables like 'general_log';

MySQL常用性能指标_mysql_15


开启通用查询日志:

mysql>  set global general_log=on;

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