数据库监控需要监控哪些指标呢?


文章目录

  • 1. 对数据库服务可用性进行监控
  • 2. 对数据库性能进行监控
  • 1. 周期性获取QPS和TPS
  • 2. 如何监控innodb的阻塞
  • 3. 监控buffer pool
  • 4. 监控binlog是否使用了磁盘
  • 5. 监控写的能力
  • grafana mysql dashboard
  • 1. Uptime
  • 2. Current QPS
  • 3. InnoDB Buffer Pool Size
  • 4. Connections
  • Connections
  • Max Used Connections
  • Max Connections
  • 5. Client Thread Activity
  • Peak Threads Connected
  • Peak Threads Running
  • Avg Threads Running
  • 6. Mysql Questions
  • 7. Mysql Thread Cache
  • Thread Cache Size
  • Threads Cached
  • Threads Created
  • 8. Temporary Objects
  • Created Tmp Tables
  • Created Tmp Disk Tables
  • Created Tmp Files
  • 9. Mysql Select Type
  • Select Scan
  • Select Full Join
  • Select Range
  • Select Range Check
  • Select Full Range Join
  • 10. Mysql Sort
  • Sort Rows
  • Sort Scan
  • Sort Range
  • Sort Merge Passes
  • 11. Mysql Slow Query
  • 12. Mysql Abort Connections
  • Aborted Connects (attempts)
  • Aborted Clients (timeout)
  • 13. Mysql Table Lock
  • Table Locks Immediate
  • Table Locks Waited
  • 14. Mysql Network Traffic
  • Inbound
  • Outbound
  • 15. Mysql Network Usage Hourly
  • Received
  • Sent
  • 16. Mysql Internal Memory Overview
  • InnoDB Buffer Pool Data
  • 17. Top Command Counters
  • 18. Top Command Counters Hourly
  • 19. Mysql Handler
  • 20. Mysql Transaction Handler
  • 21. Process States
  • 23. Mysql Query Cache Memory
  • Free Memory
  • Query Cache Size
  • 26. Mysql Open Files
  • Open Files
  • Open Files Limit
  • InnoDB Open Files
  • 27. Mysql Table Open Cache Status
  • Openings
  • Hits
  • Misses
  • Misses due to Overflows
  • Table Open Cache Hit Ratio
  • 28. Mysql Open Tables
  • Open Tables
  • Table Open Cache
  • 29. Mysql Table Definition Cache
  • Opened Table Definitions(right-y)
  • Table Definitions Cache Size
  • Open Table Definitions
  • 3. 对主从复制进行监控
  • 4. 对服务器资源的监控,如磁盘空间


1. 对数据库服务可用性进行监控

数据库进程或是端口存在,并不意味着数据库就能提供服务

要通过网络对数据库进行连接,并执行某些简单的数据库脚本(health check)

mysqladmin -umonitor_user -p -hip地址 ping
telnet ip db_port 手动来连接

可以连接数据库并不代表数据库可用

确认数据库是否可以读写

检查数据库的read_only参数是否为off,从服务器read_only参数最好打开,主从切换后可能忘记改回来了

建立监控表并对表中数据进行更改

执行简单的查询select @@version,来判断数据库是否可读

存在tcp/ip连接被占满的情况

出现阻塞或memcache大量缓存失效

show variables like 'max_connections'
show global status like 'threads_connected'

threads_connected/max_connections > 0.8就要报警了

2. 对数据库性能进行监控

1. 周期性获取QPS和TPS

QPS = (Queries2 - Queries1)/(Uptime_since_flush_status2-Uptime_since_flush_status1)

TPS = ((Com_insert2 + Com_update2 + Com_delete2) - (Com_insert1 + Com_update1 + Com_delete1)) / (Uptime_since_flush_status2 - Uptime_since_flush_status1)

2. 如何监控innodb的阻塞

查出阻塞时间大于60秒的语句

select b.trx_mysql_thread_id as '被阻塞线程', 
b.trx_query as '被阻塞SQL', 
c.trx_mysql_thread_id as '阻塞线程', 
c.trx_query as '阻塞SQL',
(UNIX_TIMESTAMP()-UNIX_TIMESTAMP(c.trx_started)) as '阻塞时间'
from information_schema.innodb_lock_waits a 
join information_schema.innodb_trx b on a.requesting_trx_id = b.trx_id
join information_schema.innodb_trx c on a.blocking_trx_id = c.trx_id
where (UNIX_TIMESTAMP()-UNIX_TIMESTAMP(c.trx_started)) > 1;

MySql 监控指标时序异常 mysql数据库监控指标_sql

select id, user, host, DB, command, time, state, info from information_schema.PROCESSLIST\G

MySql 监控指标时序异常 mysql数据库监控指标_数据库_02

通过在session1上执行

select connection_id();

获得id

3. 监控buffer pool

select * from information_schema.INNODB_BUFFER_POOL_STATS\G

free_buffers接近为0,database_pages接近pool_size的值,说明数据库压力很大。

4. 监控binlog是否使用了磁盘

监控的时候可以看一下binlog_cache_disk_use这个值是否比较大,如果比较大,那说明binlog cache可能不够大

5. 监控写的能力

innodb_io_capacity,默认是200。这个参数控制多少个脏页触发checkpoint,以这个参数很重要,值大一点,那么写的能力就会提高起来,但如果值很大,那么可能就会hang住

这个参数是innodb调优需要很关注,但是很容易忽略的一个点

grafana mysql dashboard

以下面这个grafana mysql dashboard为例说明

MySql 监控指标时序异常 mysql数据库监控指标_mysql_03


完整效果

MySql 监控指标时序异常 mysql数据库监控指标_mysql_04

1. Uptime

SHOW GLOBAL STATUS LIKE '%Uptime%';

指标参考:https://dev.mysql.com/doc/refman/5.7/en/server-status-variables.html#statvar_Queries

Uptime

The number of seconds that the server has been up.

2. Current QPS

SHOW GLOBAL STATUS LIKE '%queries%';
Queries

The number of statements executed by the server. This variable includes statements executed within stored programs, unlike the Questions variable. It does not count COM_PING or COM_STATISTICS commands.

The discussion at the beginning of this section indicates how to relate this statement-counting status variable to other such variables.

grafana中

rate(mysql_global_status_queries{instance="$host"}[$interval]) or irate(mysql_global_status_queries{instance="$host"}[5m])

3. InnoDB Buffer Pool Size

mysql 缓冲池 buffer pool 所占大小

4. Connections

Connections
SHOW GLOBAL STATUS LIKE '%threads_connected%';
Threads_connected

The number of currently open connections.

grafana统计规则是:

max(max_over_time(mysql_global_status_threads_connected{instance="$host"}[$interval])  or mysql_global_status_threads_connected{instance="$host"} )
Max Used Connections
SHOW GLOBAL STATUS LIKE '%max_used_connections%';
Max_used_connections

The maximum number of connections that have been in use simultaneously since the server started.

Max_used_connections_time

The time at which Max_used_connections reached its current value.

grafana统计规则是:

mysql_global_status_max_used_connections{instance="$host"}
Max Connections
SHOW GLOBAL VARIABLES LIKE '%max_connections%';

max_connections

Property

Value

Command-Line Format

--max-connections=#

System Variable

max_connections

Scope

Global

Dynamic

Yes

Type

Integer

Default Value

151

Minimum Value

1

Maximum Value

100000

The maximum permitted number of simultaneous client connections. For more information, see Section 5.1.11.1, “Connection Interfaces”.

grafana统计规则是:

mysql_global_variables_max_connections{instance="$host"}

5. Client Thread Activity

Peak Threads Connected
SHOW GLOBAL STATUS LIKE '%threads_connected%';
Threads_connected

The number of currently open connections.

grafana统计规则:

max_over_time(mysql_global_status_threads_connected{instance="$host"}[$interval]) or
max_over_time(mysql_global_status_threads_connected{instance="$host"}[5m])
Peak Threads Running
SHOW GLOBAL STATUS LIKE '%threads_running%';
Threads_running

The number of threads that are not sleeping.

grafana统计规则:

max_over_time(mysql_global_status_threads_running{instance="$host"}[$interval]) or
max_over_time(mysql_global_status_threads_running{instance="$host"}[5m])
Avg Threads Running

grafana统计规则:

avg_over_time(mysql_global_status_threads_running{instance="$host"}[$interval]) or 
avg_over_time(mysql_global_status_threads_running{instance="$host"}[5m])

6. Mysql Questions

SHOW GLOBAL STATUS LIKE '%questions%';
  • QuestionsThe number of statements executed by the server. This includes only statements sent to the server by clients and not statements executed within stored programs, unlike the Queries variable. This variable does not count COM_PING, COM_STATISTICS, COM_STMT_PREPARE, COM_STMT_CLOSE, or COM_STMT_RESET commands.
    The discussion at the beginning of this section indicates how to relate this statement-counting status variable to other such variables.

grafana统计规则

rate(mysql_global_status_questions{instance="$host"}[$interval]) or irate(mysql_global_status_questions{instance="$host"}[5m])

7. Mysql Thread Cache

Thread Cache Size
SHOW GLOBAL VARIABLES LIKE '%thread_cache_size%';

thread_cache_size

Property

Value

Command-Line Format

--thread-cache-size=#

System Variable

thread_cache_size

Scope

Global

Dynamic

Yes

Type

Integer

Default Value

-1 (signifies autosizing; do not assign this literal value)

Minimum Value

0

Maximum Value

16384

How many threads the server should cache for reuse. When a client disconnects, the client’s threads are put in the cache if there are fewer than thread_cache_size threads there. Requests for threads are satisfied by reusing threads taken from the cache if possible, and only when the cache is empty is a new thread created. This variable can be increased to improve performance if you have a lot of new connections. Normally, this does not provide a notable performance improvement if you have a good thread implementation. However, if your server sees hundreds of connections per second you should normally set thread_cache_size high enough so that most new connections use cached threads. By examining the difference between the Connections and Threads_created status variables, you can see how efficient the thread cache is. For details, see Section 5.1.9, “Server Status Variables”.

The default value is based on the following formula, capped to a limit of 100:

8 + (max_connections / 100)

This variable has no effect for the embedded server (libmysqld) and as of MySQL 5.7.2 is no longer visible within the embedded server.

grafana统计规则

mysql_global_variables_thread_cache_size{instance="$host"}
Threads Cached
SHOW GLOBAL STATUS LIKE '%threads_cached%';

Threads_cached

The number of threads in the thread cache.

This variable is not meaningful in the embedded server (libmysqld) and as of MySQL 5.7.2 is no longer visible within the embedded server.

grafana统计规则

mysql_global_status_threads_cached{instance="$host"}
Threads Created
SHOW GLOBAL STATUS LIKE '%threads_created%';

Threads_created

The number of threads created to handle connections. If Threads_created is big, you may want to increase the thread_cache_size value. The cache miss rate can be calculated as Threads_created/Connections.

miss cache rate = 9320/7672870 = 0.1%

grafana统计规则

rate(mysql_global_status_threads_created{instance="$host"}[$interval]) or irate(mysql_global_status_threads_created{instance="$host"}[5m])

8. Temporary Objects

Created Tmp Tables
SHOW GLOBAL STATUS LIKE '%created_tmp_tables%';

Created_tmp_tables

The number of internal temporary tables created by the server while executing statements.

You can compare the number of internal on-disk temporary tables created to the total number of internal temporary tables created by comparing the values of the Created_tmp_disk_tables and Created_tmp_tables variables.

See also Section 8.4.4, “Internal Temporary Table Use in MySQL”.

Each invocation of the SHOW STATUS statement uses an internal temporary table and increments the global Created_tmp_tables value.

grafana统计规则

rate(mysql_global_status_created_tmp_tables{instance="$host"}[$interval]) or irate(mysql_global_status_created_tmp_tables{instance="$host"}[5m])
Created Tmp Disk Tables
SHOW GLOBAL STATUS LIKE '%created_tmp_disk_tables%';

Created_tmp_disk_tables

The number of internal on-disk temporary tables created by the server while executing statements.

If an internal temporary table is created initially as an in-memory table but becomes too large, MySQL automatically converts it to an on-disk table. The maximum size for in-memory temporary tables is the minimum of the tmp_table_size and max_heap_table_size values. If Created_tmp_disk_tables is large, you may want to increase the tmp_table_size or max_heap_table_size value to lessen the likelihood that internal temporary tables in memory will be converted to on-disk tables.

You can compare the number of internal on-disk temporary tables created to the total number of internal temporary tables created by comparing the values of the Created_tmp_disk_tables and Created_tmp_tables variables.

See also Section 8.4.4, “Internal Temporary Table Use in MySQL”.

grafana统计规则

rate(mysql_global_status_created_tmp_disk_tables{instance="$host"}[$interval]) or irate(mysql_global_status_created_tmp_disk_tables{instance="$host"}[5m])
Created Tmp Files
SHOW GLOBAL STATUS LIKE '%created_tmp_files%';

Created_tmp_files

How many temporary files mysqld has created.

grafana统计规则

rate(mysql_global_status_created_tmp_files{instance="$host"}[$interval]) or irate(mysql_global_status_created_tmp_files{instance="$host"}[5m])

9. Mysql Select Type

Select Scan
SHOW GLOBAL STATUS LIKE '%select_scan%';

Select_scan

The number of joins that did a full scan of the first table.

grafana

rate(mysql_global_status_select_scan{instance="$host"}[$interval]) or irate(mysql_global_status_select_scan{instance="$host"}[5m])
Select Full Join
SHOW GLOBAL STATUS LIKE '%select_full_join%';

Select_full_join

The number of joins that perform table scans because they do not use indexes. If this value is not 0, you should carefully check the indexes of your tables.

grafana

rate(mysql_global_status_select_full_join{instance="$host"}[$interval]) or irate(mysql_global_status_select_full_join{instance="$host"}[5m])
Select Range
SHOW GLOBAL STATUS LIKE '%select_range%';

Select_range

The number of joins that used ranges on the first table. This is normally not a critical issue even if the value is quite large.

grafana

rate(mysql_global_status_select_range{instance="$host"}[$interval]) or irate(mysql_global_status_select_range{instance="$host"}[5m])
Select Range Check
SHOW GLOBAL STATUS LIKE '%select_range_check%';

Select_range_check

The number of joins without keys that check for key usage after each row. If this is not 0, you should carefully check the indexes of your tables.

grafana

rate(mysql_global_status_select_range_check{instance="$host"}[$interval]) or irate(mysql_global_status_select_range_check{instance="$host"}[5m])
Select Full Range Join
SHOW GLOBAL STATUS LIKE '%select_full_range_join%';

Select_full_range_join

The number of joins that used a range search on a reference table.

grafana

rate(mysql_global_status_select_full_range_join{instance="$host"}[$interval]) or irate(mysql_global_status_select_full_range_join{instance="$host"}[5m])

10. Mysql Sort

Sort Rows
SHOW GLOBAL STATUS LIKE '%sort_rows%';

Sort_rows

The number of sorted rows.

grafana

rate(mysql_global_status_sort_rows{instance="$host"}[$interval]) or irate(mysql_global_status_sort_rows{instance="$host"}[5m])
Sort Scan
SHOW GLOBAL STATUS LIKE '%sort_scan%';

Sort_scan

The number of sorts that were done by scanning the table.

grafana

rate(mysql_global_status_sort_scan{instance="$host"}[$interval]) or irate(mysql_global_status_sort_scan{instance="$host"}[5m])
Sort Range
SHOW GLOBAL STATUS LIKE '%sort_range%';

Sort_range

The number of sorts that were done using ranges.

Sort Merge Passes
SHOW GLOBAL STATUS LIKE '%sort_merge_passes%';

Sort_merge_passes

The number of merge passes that the sort algorithm has had to do. If this value is large, you should consider increasing the value of the sort_buffer_size system variable.

grafana

rate(mysql_global_status_sort_merge_passes{instance="$host"}[$interval]) or irate(mysql_global_status_sort_merge_passes{instance="$host"}[5m])

11. Mysql Slow Query

SHOW GLOBAL STATUS LIKE '%slow_queries%';

Slow_queries

The number of queries that have taken more than long_query_time seconds. This counter increments regardless of whether the slow query log is enabled. For information about that log, see Section 5.4.5, “The Slow Query Log”.

SHOW GLOBAL VARIABLES LIKE '%long_query_time%';

long_query_time

Property

Value

Command-Line Format

--long-query-time=#

System Variable

long_query_time

Scope

Global, Session

Dynamic

Yes

Type

Numeric

Default Value

10

Minimum Value

0

If a query takes longer than this many seconds, the server increments the Slow_queries status variable. If the slow query log is enabled, the query is logged to the slow query log file. This value is measured in real time, not CPU time, so a query that is under the threshold on a lightly loaded system might be above the threshold on a heavily loaded one. The minimum and default values of long_query_time are 0 and 10, respectively. The value can be specified to a resolution of microseconds. See Section 5.4.5, “The Slow Query Log”.

Smaller values of this variable result in more statements being considered long-running, with the result that more space is required for the slow query log. For very small values (less than one second), the log may grow quite large in a small time. Increasing the number of statements considered long-running may also result in false positives for the “excessive Number of Long Running Processes” alert in MySQL Enterprise Monitor, especially if Group Replication is enabled. For these reasons, very small values should be used in test environments only, or, in production environments, only for a short period.

grafana

rate(mysql_global_status_slow_queries{instance="$host"}[$interval]) or irate(mysql_global_status_slow_queries{instance="$host"}[5m])

12. Mysql Abort Connections

Aborted Connects (attempts)
SHOW GLOBAL STATUS LIKE '%aborted_connects%';

Aborted_connects

The number of failed attempts to connect to the MySQL server. See Section B.4.2.10, “Communication Errors and Aborted Connections”.

For additional connection-related information, check the Connection_errors_*xxx* status variables and the host_cache table.

As of MySQL 5.7.3, Aborted_connects is not visible in the embedded server because for that server it is not updated and is not meaningful.

grafana

rate(mysql_global_status_aborted_connects{instance="$host"}[$interval]) or irate(mysql_global_status_aborted_connects{instance="$host"}[5m])
Aborted Clients (timeout)
SHOW GLOBAL STATUS LIKE '%aborted_clients%';

Aborted_clients

The number of connections that were aborted because the client died without closing the connection properly. See Section B.4.2.10, “Communication Errors and Aborted Connections”.

grafana

rate(mysql_global_status_aborted_clients{instance="$host"}[$interval]) or irate(mysql_global_status_aborted_clients{instance="$host"}[5m])

13. Mysql Table Lock

Table Locks Immediate
SHOW GLOBAL STATUS LIKE '%table_locks_immediate%';

Table_locks_immediate

The number of times that a request for a table lock could be granted immediately.

grafana

rate(mysql_global_status_table_locks_immediate{instance="$host"}[$interval]) or irate(mysql_global_status_table_locks_immediate{instance="$host"}[5m])
Table Locks Waited
SHOW GLOBAL STATUS LIKE '%table_locks_waited%';

Table_locks_waited

The number of times that a request for a table lock could not be granted immediately and a wait was needed. If this is high and you have performance problems, you should first optimize your queries, and then either split your table or tables or use replication.

grafana

rate(mysql_global_status_table_locks_waited{instance="$host"}[$interval]) or irate(mysql_global_status_table_locks_waited{instance="$host"}[5m])

14. Mysql Network Traffic

Inbound
SHOW GLOBAL STATUS LIKE '%bytes_receive%';

Bytes_received

The number of bytes received from all clients.

grafana

rate(mysql_global_status_bytes_received{instance="$host"}[$interval]) or irate(mysql_global_status_bytes_received{instance="$host"}[5m])
Outbound
SHOW GLOBAL STATUS LIKE '%bytes_sent%';

Bytes_sent

The number of bytes sent to all clients.

grafana

rate(mysql_global_status_bytes_sent{instance="$host"}[$interval]) or irate(mysql_global_status_bytes_sent{instance="$host"}[5m])

15. Mysql Network Usage Hourly

Received

grafana

increase(mysql_global_status_bytes_received{instance="$host"}[1h])
Sent

grafana

increase(mysql_global_status_bytes_sent{instance="$host"}[1h])

16. Mysql Internal Memory Overview

InnoDB Buffer Pool Data
SHOW GLOBAL STATUS LIKE '%innodb_page_size%';

Innodb_page_size

InnoDB page size (default 16KB). Many values are counted in pages; the page size enables them to be easily converted to bytes.

SHOW GLOBAL STATUS LIKE '%buffer_pool_pages_data%';

2375181*16Kb = 36G

grafana

mysql_global_status_innodb_page_size{instance="$host"} * on (instance) mysql_global_status_buffer_pool_pages{instance="$host",state="data"}

17. Top Command Counters

SHOW GLOBAL STATUS LIKE '%Com%';
SHOW GLOBAL STATUS LIKE '%Com_select%';
SHOW GLOBAL STATUS LIKE '%Com_set_option%';
SHOW GLOBAL STATUS LIKE '%Com_commit%';
SHOW GLOBAL STATUS LIKE '%Com_update%';
SHOW GLOBAL STATUS LIKE '%Com_insert%';
SHOW GLOBAL STATUS LIKE '%Com_admin_commands%';
SHOW GLOBAL STATUS LIKE '%Com_insert_select%';
Com_*`xxx`*

The Com_*xxx* statement counter variables indicate the number of times each xxx statement has been executed. There is one status variable for each type of statement. For example, Com_delete and Com_update count DELETE and UPDATE statements, respectively. Com_delete_multi and Com_update_multi are similar but apply to DELETE and UPDATE statements that use multiple-table syntax.

If a query result is returned from query cache, the server increments the Qcache_hits status variable, not Com_select. See Section 8.10.3.4, “Query Cache Status and Maintenance”.

All Com_stmt_*xxx* variables are increased even if a prepared statement argument is unknown or an error occurred during execution. In other words, their values correspond to the number of requests issued, not to the number of requests successfully completed. For example, because status variables are initialized for each server startup and do not persist across restarts, the Com_shutdown variable that tracks SHUTDOWN statements normally has a value of zero, but can be nonzero if SHUTDOWN statements were executed but failed.

grafana

topk(5, rate(mysql_global_status_commands_total{instance="$host"}[$interval])>0) or topk(5, irate(mysql_global_status_commands_total{instance="$host"}[5m])>0)

18. Top Command Counters Hourly

grafana

topk(5, increase(mysql_global_status_commands_total{instance="$host"}[1h])>0)

19. Mysql Handler

SHOW GLOBAL STATUS LIKE '%handler_%';
  • Handler_read_rnd_nextThe number of requests to read the next row in the data file. This value is high if you are doing a lot of table scans. Generally this suggests that your tables are not properly indexed or that your queries are not written to take advantage of the indexes you have.
  • Handler_read_nextThe number of requests to read the next row in key order. This value is incremented if you are querying an index column with a range constraint or if you are doing an index scan.
  • Handler_writeThe number of requests to insert a row in a table.
  • Handler_read_keyThe number of requests to read a row based on a key. If this value is high, it is a good indication that your tables are properly indexed for your queries.
  • Handler_updateThe number of requests to update a row in a table.
  • Handler_read_prevThe number of requests to read the previous row in key order. This read method is mainly used to optimize ORDER BY ... DESC.
  • Handler_read_rndThe number of requests to read a row based on a fixed position. This value is high if you are doing a lot of queries that require sorting of the result. You probably have a lot of queries that require MySQL to scan entire tables or you have joins that do not use keys properly.
  • Handler_read_firstThe number of times the first entry in an index was read. If this value is high, it suggests that the server is doing a lot of full index scans (for example, SELECT col1 FROM foo, assuming that col1 is indexed).
  • Handler_external_lockThe server increments this variable for each call to its external_lock() function, which generally occurs at the beginning and end of access to a table instance. There might be differences among storage engines. This variable can be used, for example, to discover for a statement that accesses a partitioned table how many partitions were pruned before locking occurred: Check how much the counter increased for the statement, subtract 2 (2 calls for the table itself), then divide by 2 to get the number of partitions locked.
  • Handler_read_lastThe number of requests to read the last key in an index. With ORDER BY, the server will issue a first-key request followed by several next-key requests, whereas with ORDER BY DESC, the server will issue a last-key request followed by several previous-key requests.

grafana

rate(mysql_global_status_handlers_total{instance="$host", handler!~"commit|rollback|savepoint.*|prepare"}[$interval]) or irate(mysql_global_status_handlers_total{instance="$host", handler!~"commit|rollback|savepoint.*|prepare"}[5m])

20. Mysql Transaction Handler

SHOW GLOBAL STATUS LIKE '%handler_commit%';
SHOW GLOBAL STATUS LIKE '%handler_prepare%';
SHOW GLOBAL STATUS LIKE '%handler_rollback%';

Handler_commit

The number of internal COMMIT statements.

Handler_prepare

A counter for the prepare phase of two-phase commit operations.

Handler_rollback

The number of requests for a storage engine to perform a rollback operation.

Handler_savepoint

The number of requests for a storage engine to place a savepoint.

grafana

rate(mysql_global_status_handlers_total{instance="$host", handler=~"commit|rollback|savepoint.*|prepare"}[$interval]) or irate(mysql_global_status_handlers_total{instance="$host", handler=~"commit|rollback|savepoint.*|prepare"}[5m])

21. Process States

为什么显示不出来呢?

看起来其使用了information_schema这个库

info_schema_processlist.go

processlistCountDesc = prometheus.NewDesc(
		prometheus.BuildFQName(namespace, informationSchema, "threads"),
		"The number of threads (connections) split by current state.",
		[]string{"state"}, nil)

23. Mysql Query Cache Memory

Free Memory
SHOW GLOBAL STATUS LIKE '%qcache_free_memory%';

Qcache_free_memory

The amount of free memory for the query cache.

Note

The query cache is deprecated as of MySQL 5.7.20, and is removed in MySQL 8.0. Deprecation includes Qcache_free_memory.

grafana

mysql_global_status_qcache_free_memory{instance="$host"}
Query Cache Size
SHOW GLOBAL VARIABLES LIKE '%query_cache_size%';

query_cache_size

Property

Value

Command-Line Format

--query-cache-size=#

Deprecated

5.7.20

System Variable

query_cache_size

Scope

Global

Dynamic

Yes

Type

Integer

Default Value

1048576

Minimum Value

0

Maximum Value (64-bit platforms)

18446744073709551615

Maximum Value (32-bit platforms)

4294967295

The amount of memory allocated for caching query results. By default, the query cache is disabled. This is achieved using a default value of 1M, with a default for query_cache_type of 0. (To reduce overhead significantly if you set the size to 0, you should also start the server with query_cache_type=0.

The permissible values are multiples of 1024; other values are rounded down to the nearest multiple. For nonzero values of query_cache_size, that many bytes of memory are allocated even if query_cache_type=0. See Section 8.10.3.3, “Query Cache Configuration”, for more information.

The query cache needs a minimum size of about 40KB to allocate its structures. (The exact size depends on system architecture.) If you set the value of query_cache_size too small, a warning will occur, as described in Section 8.10.3.3, “Query Cache Configuration”.

Note

The query cache is deprecated as of MySQL 5.7.20, and is removed in MySQL 8.0. Deprecation includes query_cache_size.

grafana

mysql_global_variables_query_cache_size{instance="$host"}

26. Mysql Open Files

Open Files
SHOW GLOBAL STATUS LIKE '%open_files%';

Open_files

The number of files that are open. This count includes regular files opened by the server. It does not include other types of files such as sockets or pipes. Also, the count does not include files that storage engines open using their own internal functions rather than asking the server level to do so.

grafana

mysql_global_status_open_files{instance="$host"}
Open Files Limit
SHOW GLOBAL VARIABLES LIKE '%open_files_limit%';

open_files_limit

Property

Value

Command-Line Format

--open-files-limit=#

System Variable

open_files_limit

Scope

Global

Dynamic

No

Type

Integer

Default Value

5000, with possible adjustment

Minimum Value

0

Maximum Value

platform dependent

The number of file descriptors available to mysqld from the operating system. mysqld reserves descriptors with setrlimit(), using the value requested at startup by setting this variable directly or by using the --open-files-limit option to mysqld_safe. If mysqld produces the error Too many open files, try increasing the open_files_limit value. Internally, the maximum value for this variable is the maximum unsigned integer value, but the actual maximum is platform dependent.

The value of open_files_limit at runtime indicates the number of file descriptors actually permitted to mysqld by the operating system, which might differ from the value requested at startup. If the number of file descriptors requested during startup cannot be allocated, mysqld writes a warning to the error log.

The effective open_files_limit value is based on the value specified at system startup (if any) and the values of max_connections and table_open_cache, using these formulas:

  • 10 + max_connections + (table_open_cache * 2)
  • max_connections * 5
  • Operating system limit if that limit is positive but not Infinity
  • If operating system limit is Infinity: open_files_limit value if specified at startup, 5000 if not

The server attempts to obtain the number of file descriptors using the maximum of those values. If that many descriptors cannot be obtained, the server attempts to obtain as many as the system will permit.

The effective value is 0 on systems where MySQL cannot change the number of open files.

On Unix, the value cannot be set greater than ulimit -n.

grafana

mysql_global_variables_open_files_limit{instance="$host"}
InnoDB Open Files
SHOW GLOBAL STATUS LIKE '%innodb_num_open_files%';

Innodb_num_open_files

The number of files InnoDB currently holds open.

grafana

mysql_global_status_innodb_num_open_files{instance="$host"}

27. Mysql Table Open Cache Status

Openings
SHOW GLOBAL STATUS LIKE '%opened_tables%';

Open_tables

The number of tables that are open.

grafana

rate(mysql_global_status_opened_tables{instance="$host"}[$interval]) or irate(mysql_global_status_opened_tables{instance="$host"}[5m])
Hits
SHOW GLOBAL STATUS LIKE '%table_open_cache_hits%';

Table_open_cache_hits

The number of hits for open tables cache lookups.

grafana

rate(mysql_global_status_table_open_cache_hits{instance="$host"}[$interval]) or irate(mysql_global_status_table_open_cache_hits{instance="$host"}[5m])
Misses
SHOW GLOBAL STATUS LIKE '%table_open_cache_misses%';

Table_open_cache_misses

The number of misses for open tables cache lookups.

grafana

rate(mysql_global_status_table_open_cache_misses{instance="$host"}[$interval]) or irate(mysql_global_status_table_open_cache_misses{instance="$host"}[5m])
Misses due to Overflows
SHOW GLOBAL STATUS LIKE '%table_open_cache_overflows%';

The number of overflows for the open tables cache. This is the number of times, after a table is opened or closed, a cache instance has an unused entry and the size of the instance is larger than table_open_cache / table_open_cache_instances.

grafana

rate(mysql_global_status_table_open_cache_overflows{instance="$host"}[$interval]) or irate(mysql_global_status_table_open_cache_overflows{instance="$host"}[5m])
Table Open Cache Hit Ratio

grafana

(rate(mysql_global_status_table_open_cache_hits{instance="$host"}[$interval]) or irate(mysql_global_status_table_open_cache_hits{instance="$host"}[5m]))/((rate(mysql_global_status_table_open_cache_hits{instance="$host"}[$interval]) or irate(mysql_global_status_table_open_cache_hits{instance="$host"}[5m]))+(rate(mysql_global_status_table_open_cache_misses{instance="$host"}[$interval]) or irate(mysql_global_status_table_open_cache_misses{instance="$host"}[5m])))

28. Mysql Open Tables

Open Tables

Openings表示的是rate 这里是总量

grafana

mysql_global_status_open_tables{instance="$host"}
Table Open Cache
SHOW GLOBAL VARIABLES LIKE '%table_open_cache%';

table_open_cache

Property

Value

Command-Line Format

--table-open-cache=#

System Variable

table_open_cache

Scope

Global

Dynamic

Yes

Type

Integer

Default Value

2000

Minimum Value

1

Maximum Value

524288

The number of open tables for all threads. Increasing this value increases the number of file descriptors that mysqld requires. You can check whether you need to increase the table cache by checking the Opened_tables status variable. See Section 5.1.9, “Server Status Variables”. If the value of Opened_tables is large and you do not use FLUSH TABLES often (which just forces all tables to be closed and reopened), then you should increase the value of the table_open_cache variable. For more information about the table cache, see Section 8.4.3.1, “How MySQL Opens and Closes Tables”.

grafana

mysql_global_variables_table_open_cache{instance="$host"}

29. Mysql Table Definition Cache

Opened Table Definitions(right-y)
SHOW GLOBAL STATUS LIKE '%opened_table_definitions%';

Opened_table_definitions

The number of .frm files that have been cached.

grafana

rate(mysql_global_status_opened_table_definitions{instance="$host"}[$interval]) or irate(mysql_global_status_opened_table_definitions{instance="$host"}[5m])
Table Definitions Cache Size
SHOW GLOBAL VARIABLES LIKE '%table_definition_cache%';

table_definition_cache

Property

Value

Command-Line Format

--table-definition-cache=#

System Variable

table_definition_cache

Scope

Global

Dynamic

Yes

Type

Integer

Default Value

-1 (signifies autosizing; do not assign this literal value)

Minimum Value

400

Maximum Value

524288

The number of table definitions (from .frm files) that can be stored in the definition cache. If you use a large number of tables, you can create a large table definition cache to speed up opening of tables. The table definition cache takes less space and does not use file descriptors, unlike the normal table cache. The minimum value is 400. The default value is based on the following formula, capped to a limit of 2000:

400 + (table_open_cache / 2)

For InnoDB, table_definition_cache acts as a soft limit for the number of open table instances in the InnoDB data dictionary cache. If the number of open table instances exceeds the table_definition_cache setting, the LRU mechanism begins to mark table instances for eviction and eventually removes them from the data dictionary cache. The limit helps address situations in which significant amounts of memory would be used to cache rarely used table instances until the next server restart. The number of table instances with cached metadata could be higher than the limit defined by table_definition_cache, because InnoDB system table instances and parent and child table instances with foreign key relationships are not placed on the LRU list and are not subject to eviction from memory.

Additionally, table_definition_cache defines a soft limit for the number of InnoDB file-per-table tablespaces that can be open at one time, which is also controlled by innodb_open_files. If both table_definition_cache and innodb_open_files are set, the highest setting is used. If neither variable is set, table_definition_cache, which has a higher default value, is used. If the number of open tablespace file handles exceeds the limit defined by table_definition_cache or innodb_open_files, the LRU mechanism searches the tablespace file LRU list for files that are fully flushed and are not currently being extended. This process is performed each time a new tablespace is opened. If there are no “inactive” tablespaces, no tablespace files are closed.

grafana

mysql_global_variables_table_definition_cache{instance="$host"}
Open Table Definitions

总量

grafana

mysql_global_status_open_table_definitions{instance="$host"}

3. 对主从复制进行监控

4. 对服务器资源的监控,如磁盘空间