使用 Docker 部署 Grafana + Prometheus 监控 MySQL 数据库
一、背景
在平时开发过程当中需要针对 MySQL 数据库进行监控,这里我们可以使用 Grafana 和 Prometheus 来实现监控功能。Grafana 是一款功能强大的仪表盘面板,支持多种数据源,可以自定义图表进行监控。而 Prometheus 就是 Grafana 支持的数据源之一,Prometheus 负责采集需要监控的数据,然后通过 Grafana 展示出来。
Prometheus 拥有多种 Exporter 进行监控数据的导出,这里我们使用的是 Mysql Exporter 来进行数据库状态的监控。
很久没写博客了,最近实在太忙,工作之余在研究 Abp vNext。
二、动手实践
首先参考博文《Linux 下的 Docker 安装与使用》安装好 Docker,之后再参考博文 《CentOS 7.x 安装 Docker-Compose》安装好 Docker-Compose 之后,就可以开始我们的工作了。
2.1 编写 Docker-Compose.Yaml 文件
首先我们确定会启动起来三个服务,分别是 MySQL-Exporter (监控 MySQL 指标)、Prometheus (收集 Exporter 的数据)、Grafana (从 Prometheus 读取指标数据,并展示出来)。
所以 yaml 文件的内容大体如下,这里也增加了响应的注释方便大家学习。
version: '2'
services:
exporter:
container_name: mysql-exporter-dev
image: prom/mysqld-exporter
environment:
# 这里指定的是要监控的 MySQL 数据库,这里我们以启动的 test-mysql 容器为示范。
# 实际应用当中,应该配置为具体的数据库实例。
- DATA_SOURCE_NAME=root:root@(test-mysql:3306)/
prometheus:
container_name: prometheus
image: prom/prometheus
ports:
- "20001:9090"
# 映射普罗米修斯的配置文件,用于配置 Exporter,这里的文件应该在后面创建好,具体
# 路径以实际为准。
volumes:
- /root/Docker/Volumes/Prometheus/prometheus.yml:/etc/prometheus/prometheus.yml
grafana:
container_name: grafana
image: grafana/grafana
environment:
# 配置 Grafana 的默认根 URL。
- GF_SERVER_ROOT_URL=http://192.168.100.107:20002
# 配置 Grafana 的默认 admin 密码。
- GF_SECURITY_ADMIN_PASSWORD=admin
ports:
- "20002:3000"
# 映射 Grafana 的数据文件,方便后面进行更改。
volumes:
- /root/Docker/Volumes/Grafana:/var/lib/grafana
# 本服务只是用于演示,实际使用请注释掉本服务。
mysql:
container_name: test-mysql
image: mysql
environment:
- MYSQL_ROOT_PASSWORD=root
# 这里如果需要连接外部 MySQL 就需要处在同一个网络。
networks:
default:
external:
name: mysql-monitor
2.2 配置 prometheus.yml 文件
在 prometheus.yaml 文件当中存储了所有 Exporter 的信息,所以我们需要创建一个自己的 prometheus.yml 文件,映射到容器当中。
global:
scrape_interval: 15s
evaluation_interval: 15s
alerting:
alertmanagers:
- static_configs:
- targets:
# - alertmanager:9093
scrape_configs:
# Prometheus 监控配置
- job_name: 'prometheus'
static_configs:
- targets: ['prometheus:9090']
# MySQL 监控配置
- job_name: 'mysql'
# 抓取间隔
scrape_interval: 5s
static_configs:
# 这里配置的是具体的 MySQL Exporter 的地址,在之前的 docker compose 文件
# 定义当中,mysql exporter 的容器名为 mysql-exporter-dev。
- targets: ['mysql-exporter-dev:9104']
2.3 启动
首先我们要建立一个监控用的 Docker 网络,与 Docker Compose 文件对应:
docker network create mysql-monitor

假设 yaml 文件名称为 docker-compose.yaml ,执行以下命令来创建我们的容器。
docker-compose -f ./docker-compose.yaml -p MySQL-Monitor up -d

但是呢,有时候可能会提示以下信息,说没有对应的权限,这个时候你使用 chmod 命令改变以下 Grafana 文件夹的权限即可。

chmod -R 777 /root/Docker/Volumes/Grafana
之后,再次运行 docker-compose -f ./docker-compose.yaml -p MySQL-Monitor up -d 命令,启动服务。第一次启动可能会有点慢,Grafana 需要迁移相关的数据,等待一会儿之后访问 机器IP:20002 就可以看到 Grafana 了。
2.4 配置
首先我们需要在 Grafana 配置 Prometheus 数据源,登录 Grafana 之后,选择数据源。

选择 Prometheus。

之后在 URL 填入 Prometheus 的容器名字 + 端口,点击 Save & Test,这里一定要注意数据源的名字叫做 Prometheus,不然等会儿导入我的面板是无法使用的。

导入我们的 Dashboard 文件。


2.5 文件下载地址
三、效果图

使用 Docker 部署 Grafana + Prometheus 监控 MySQL 数据库的更多相关文章
- Grafana+Prometheus 监控 MySQL
转自:Grafana+Prometheus 监控 MySQL 架构图 环境 IP 环境 需装软件 192.168.0.237 mysql-5.7.20 node_exporter-0.15.2.lin ...
- Grafana+Prometheus监控mysql性能
#cmd /usr/local 今天讲一下如何监控服务器中的mysql数据库的性能 一.数据库操作 1.mysql启动 #service mysqld start #启动数据库 #service my ...
- Prometheus 监控Mysql服务器及Grafana可视化
Prometheus 监控Mysql服务器及Grafana可视化. mysql_exporter:用于收集MySQL性能信息. 使用版本 mysqld_exporter 0.11.0 官方地址 使用文 ...
- Docker系列——Grafana+Prometheus+Node-exporter钉钉推送(四)
近期搭建的服务器监控平台,来进行一个总结.主要分为监控平台的搭建.告警中心的配置以及消息的推送.推送的话,支持多种终端.具体详细可查看之前的博文,在这里罗列下,方便查看. Docker系列--Graf ...
- Cacti监控mysql数据库服务器实现过程
Cacti监控mysql数据库服务器实现过程 2014-05-29 0个评论 来源:Cacti监控mysql数据库服务器实现过程 收藏 我要投稿 1 先在cacti服务器端安 ...
- Docker系列——Grafana+Prometheus+Node-exporter微信推送(三)
在之前博文中,已经成功的实现了邮件推送.目前主流的办公终端,就是企业微信.钉钉.飞书.今天来分享下微信推送,我们具体来看. 企业微信 在配置企业微信推送时,需要有微信企业,具体如何注册.使用,另外百度 ...
- zabbix通过第三方插件percona监控mysql数据库
zabbix通过第三方插件percona监控mysql数据库 ...
- zabbix利用自带的模板监控mysql数据库
zabbix利用自带的模板监控mysql数据库 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 有些东西你不会的时候觉得它特别难,但是当你去做的时候就发现如此的简单~zabbix功能 ...
- zabbix3.4 监控mysql 数据库连接数
zabbix3.4 监控mysql 数据库连接数具体监控配置待定,近期即将发布!
随机推荐
- MySQL语法大全_自己整理的学习笔记(MySQL语句 整理二)
select * from emp; #注释 #--------------------------- #----命令行连接MySql--------- #启动mysql服务器 net start m ...
- ORB-SLAM2阅读笔记(一)从mono_eourc.cpp出发理解ORB-SLAM2
泡泡机器人上已经有公开课ORB-SLAM2的代码详解了,我也先看了一个多小时的视频,后来发现看完还是迷迷糊糊,自己没看源码,根本不明白讲的什么,因此,打开文件开始阅读源码. 为了阅读逻辑清楚,我从OR ...
- 【此处有干货~】jmeter+ant+jenkins持续集成配置及过程中问题解决思路
本人是一枚工作近三年的小测试,大学正好专业为软件测试,在工作中用到最多的是功能测试.接口测试.压力测试.偶尔会涉及到性能测试......(小白,很多观念技术跟大佬差距太大,勿喷) 在接口测试过程当中, ...
- Scrapy爬虫框架的学习
第一步安装 首先得安装它,我使用的pip安装的 因为我电脑上面安装了两个python,一个是python2.x,一个是python3.x,所以为了区分,所以,在cmd中,我就使用命令:python2 ...
- resin4配置之一个resin下多个app的正确配置方法
可能是因为resin4出来不久的原因,很多人对一个resin配置多个app不是很了解,经过几个小时的研究,有了一些小的成果,在此分享一下: 在开发的时候很多人习惯了一个resin下配置多个app,习惯 ...
- P1081 开车旅行(Not Finish)
https://www.luogu.org/problemnew/show/P1081
- linux 启动weblogic重定向日志
命令启动 nohup ./startWebLogic.sh 会默认输出nohup.out日志文件 时间久了日志文件会很大,占用空前(正常项目会自己处理日志输出,不需要用到nohup的默认输出日志) ...
- 解决ORA-30036:无法按8扩展段(在还原表空间‘XXXX’中)
在update一数据量很大的表时,提示“ORA-30036:无法按8扩展段” 度娘了下原因与解决办法: 1.查询了一下undo表空间的使用,发现已经超过了80% SELECT a.tablespa ...
- 线程中的join方法
join方法的作用是同步线程. 1.不使用join方法:当设置多个线程时,在一般情况下(无守护线程,setDeamon=False),多个线程同时启动,主线程执行完,会等待其他子线程执行完,程序才会退 ...
- ASP.NET代码调用SQL Server带DateTime类型参数的存储过程抛出异常问题
ASP.NET代码调用SQL Server带DateTime类型参数的存储过程,如果DateTime类型参数的值是'0001/1/1 0:00:00'时,就会抛出异常“Message: SqlDate ...