Use prometheus to count the remaining available percentage of MySQL auto-increment primary keys

Use prometheus to count the remaining available percentage of MySQL auto-increment primary keys

Recently, a database in the production environment wrote log data crazily, causing primary key value overflow, so it is necessary to monitor this indicator.

mysqld_exporter comes with this feature. Here are the startup parameters I use:

nohup ./mysqld_exporter --config.my-cnf="./my.cnf" --web.listen-address=":9104" --collect.heartbeat --collect.auto_increment.columns --collect.binlog_size --collect.engine_innodb_status --collect.engine_tokudb_status --collect.slave_hosts --collect.slave_status --collect.info_schema.processlist --collect.info_schema.innodb_metrics > /dev/null 2>&1 &

The parameters highlighted in red are used to collect the usage of the auto-increment ID.

The SQL actually executed is similar to this:

SELECT 
 table_schema,
 table_name,
 column_name,
 AUTO_INCREMENT,
 POW(2, CASE data_type
   WHEN 'tinyint' THEN 7
   WHEN 'smallint' THEN 15
   WHEN 'mediumint' THEN 23
   WHEN 'int' THEN 31
   WHEN 'bigint' THEN 63
   END+(column_type LIKE '% unsigned'))-1 AS max_int 
  FROM information_schema.tables t
   JOIN information_schema.columns c USING (table_schema,table_name)
  WHERE
   c.extra = 'auto_increment' 
  AND
   t.TABLE_SCHEMA NOT IN ('information_schema','mysql', 'sys','test','performance_schema') 
  AND
   t.auto_increment IS NOT NULL; 

In the Prometheus web interface, we can test and write the following promql to find the library + table name of the instance with the remaining auto-increment ID rate less than 40%

(mysql_info_schema_auto_increment_column_max{schema!~'test|mysql'} - mysql_info_schema_auto_increment_column{schema!~'test|mysql'})/mysql_info_schema_auto_increment_column_max{schema!~'test|mysql'}*100 < 40

After obtaining the data, we can configure relevant alarms in the alertmanager, or draw a graph on grafana, as follows:

This is the end of this article about using prometheus to count the remaining available percentage of MySQL auto-increment primary keys. For more relevant prometheus statistics on MySQL auto-increment primary keys, please search for previous articles on 123WORDPRESS.COM or continue to browse the following related articles. I hope everyone will support 123WORDPRESS.COM in the future!

You may also be interested in:
  • Use Grafana+Prometheus to monitor MySQL service performance
  • Detailed explanation of performance monitoring of MySQL server using Prometheus and Grafana
  • SpringBoot sample code using prometheus monitoring
  • Example of integrating prometheus monitoring with springboot2.X
  • Detailed steps for SpringBoot+Prometheus+Grafana to implement application monitoring and alarm
  • Detailed installation and configuration tutorial of Prometheus
  • Prometheus Getting Started Tutorial: SpringBoot Implements Custom Metrics Monitoring
  • Detailed explanation of the process of developing the middleware Exporter in Prometheus
  • How to integrate Prometheus with springboot
  • How to write custom indicators using the prometheus python library (complete code)
  • Detailed explanation of the tutorial on monitoring Springboot applications using Prometheus+Grafana
  • Prometheus monitors MySQL using grafana display

<<:  Detailed Explanation of JavaScript Framework Design Patterns

>>:  Modularity in Node.js, npm package manager explained

Recommend

About the problem of writing plugins for mounting DOM in vue3

Compared with vue2, vue3 has an additional concep...

Teach you how to install docker on windows 10 home edition

When I wrote the Redis book and the Spring Cloud ...

Detailed explanation of JavaScript timers

Table of contents Brief Introduction setInterval ...

CSS scroll-snap scroll event stop and element position detection implementation

1. Scroll Snap is a must-have skill for front-end...

Basic usage of exists, in and any in MySQL

【1】exists Use a loop to query the external table ...

JavaScript to achieve digital clock effect

This article example shares the specific code of ...

Design theory: people-oriented green design

Reflections on the two viewpoints of “people-orie...

Detailed explanation of the use of shared memory in nginx

In the nginx process model, tasks such as traffic...

Detailed explanation of CSS background and border tag examples

1. CSS background tag 1. Set the background color...

MySQL 5.7.17 installation and configuration tutorial under CentOS6.9

CentOS6.9 installs Mysql5.7 for your reference, t...

Solution to the problem that Docker container cannot access Jupyter

In this project, the Docker container is used to ...

Detailed explanation of for loop and double for loop in JavaScript

for loop The for loop loops through the elements ...

Docker data volume container creation and usage analysis

A data volume container is a container specifical...