In this experimental scenario , gathering the table growth statistics using query exporter and loading the data into time series Prometheus database . Grafana dashboards shows the growth in minutes basis
Table growth statistics gathered from localhost mysql instance for testing purpose
Frequently receiving questions like , how to we monitor the data growth of each critical tables. We can have some statistics about data growth and add convenient space for future
Launched three separate docker containers ( Query Exporter , Prometheus and PMM Server ) for each components . Added additional Dashboards in PMM Server for testing purpose
data:image/s3,"s3://crabby-images/6a050/6a050551027cbaedd2c8a0567f96cc64b08796f8" alt=""
Prometheus and Query Exporter Configuration files mapped with localhost volume like below ,
docker run -p 9560:9560/tcp -v "$PWD/config.yaml:/config.yaml" --rm -it adonato/query-exporter:latest -- /config.yaml docker run -p 9090:9090 -v /tmp/prometheus.yml:/etc/prometheus/prometheus.yml prom/prometheus
config.yaml ( Query Exporter configuration file ) :
databases:
datablogs:
dsn: mysql://queryexporter:test123@172.31.90.32:3306/test
keep-connected: true
metrics:
metric1:
type: gauge
# type: counter
description: A sample gauge
queries:
query1:
interval: 3s
databases: [datablogs]
metrics: [metric1]
sql: SELECT TABLE_ROWS as metric1 FROM information_schema.tables WHERE table_schema = 'test' and table_name='actor';
prometheus ( Prometheus configuration file ) :
global:
scrape_interval: 15s
scrape_configs:
- job_name: 'queryexporter'
scrape_interval: 5s
static_configs:
- targets: ['172.17.0.3:9560']
Both Query Exporter and Prometheus docker container started and we have to allow appropriate ports to access the web console through browser
data:image/s3,"s3://crabby-images/ef5a9/ef5a97c26caa13cd25acd7890b89033002ab6419" alt=""
Lets verify the Query Exporter and Prometheus running status
data:image/s3,"s3://crabby-images/7e20c/7e20cd893a5225e4ad868af5d7acea3f87de807e" alt=""
data:image/s3,"s3://crabby-images/59663/596637f4633278576c474b606e435fe661d5d004" alt=""
Query Exporter is gathering the statistics and loading the data into Prometheus database . Then
Add the Prometheus data source into Grafana
data:image/s3,"s3://crabby-images/f0c7a/f0c7a3b6aeaf44bb98d97b08777e5506f5e08f45" alt=""
Using the collected metrics display the dashboards on every minutes
data:image/s3,"s3://crabby-images/37478/374784bc92a696ffc1a8539cb0e6ccd4deefc9c9" alt=""
References :
Query Exporter : https://github.com/albertodonato/query-exporter
PMM Server : https://www.percona.com/doc/percona-monitoring-and-management/2.x/install/docker-setting-up.html
Prometheus : https://www.digitalocean.com/community/tutorials/how-to-install-prometheus-using-docker-on-ubuntu-14-04
0 comments:
Post a Comment