Docker部署Grafana+Promethus监控Mysql和服务器

一、Grafana部署所需资源

Grafana 需要最少的系统资源:

  • 建议的最小内存:512 MB
  • 建议的最低 CPU:1

官方文档:https://grafana.com/docs/grafana/latest/getting-started/build-first-dashboard/

可以看到,我的这台服务器,部署了Grafana+Promethus,已经占了1个G左右的内存。

这是另一台被监控的服务器,部署了Mysql、Node-Exporter、Mysql-Export,占了1个多G的内存。

以上,就是给大家一个资源评估的建议,接下来我们对这两台服务器称为A服务器、B服务器,整个服务的部署以及数据流通如下图所示:

二、搭建MYSQL

  1. 拉取镜像
shell 复制代码
docker pull hub.c.163.com/library/mysql:latest
  1. 创建宿主机的挂载数据卷
shell 复制代码
mkdir -p /opt/mysql/data
  1. 启动容器
shell 复制代码
docker run -p 3306:3306 --restart="always" --name mysql -v /opt/mysql/data:/var/lib/mysql \
-e MYSQL_ROOT_PASSWORD=123456 -d --privileged=true hub.c.163.com/library/mysql:latest
  1. 为容器创建exporter用户
shell 复制代码
#进入容器
docker exec -it mysql bash
#进入mysql
mysql -uroot -p123456
# 创建数据库用户
mysql>create user 'exporter' @ 'localhost' identified by '123456';
# 查看主从运行情况及所有数据库
mysql>grant process,replication client,select on *.* TO 'exporter '@' localhost ' ;
  1. 查看容器是否正常启动
shell 复制代码
#查看所有运行中的容器
docker ps

三、搭建mysql-exporter

  1. 拉取镜像
shell 复制代码
docker pull prom/mysqld-exporter
  1. 创建配置文件
shell 复制代码
vim /opt/my.cnf
#输入以下内容
[client]
host=主机ip 
user=用户
password=密码
  1. 启动容器
shell 复制代码
docker run -d --restart="always" -name mysql-exporter -p 9104:9104 -v /opt/my.cnf:/etc/mysql/my.cnf prom/mysqld-exporter  --config.my-cnf=/etc/mysql/my.cnf
  1. 查看服务是否在监听

访问http://主机ip:9104

四、搭建node-exporter

  1. 拉取镜像
shell 复制代码
docker pull prom/prometheus
  1. 启动容器
shell 复制代码
docker run -d -p 9100:9100 \
  -v "/proc:/host/proc:ro" \
  -v "/sys:/host/sys:ro" \
  -v "/:/rootfs:ro" \
  --net="host" \
  --name node-expoter \
  prom/node-exporter
  1. 查看服务是否在监听

访问http://主机ip:9100

五、搭建prometheus

  1. 拉取镜像
shell 复制代码
docker pull prom/node-exporte
  1. 新建目录,生成prometheus.yml
shell 复制代码
mkdir /opt/prometheus
cd /opt/prometheus/
vim prometheus.yml
#输入以下内容
global:
  scrape_interval:     60s
  evaluation_interval: 60s

scrape_configs:
  - job_name: prometheus
    static_configs:
      - targets: ['localhost:9090']
        labels:
          instance: prometheus

  - job_name: linux
    static_configs:
      - targets: ['192.168.119.128:9100']
        labels:
          instance: localhost

  - job_name: mysql
    static_configs:
      - targets: ['192.168.119.128:9104']
        labels:
          instance: mysql
  1. 启动容器
shell 复制代码
docker run  -d \
  -p 9090:9090 \
  -v /opt/prometheus/prometheus.yml:/etc/prometheus/prometheus.yml  \
  --name prometheus \
  prom/prometheus
  1. 查看服务是否在监听

访问http://主机ip:9090/targets,看到启动的相关服务是up就可以了

六、搭建Grafana

  1. 拉取镜像
shell 复制代码
docker pull grafana/grafana
  1. 启动容器

访问地址:http://IP:3000 默认账号密码都是admin

shell 复制代码
 docker run -d -p 3000:3000 grafana/grafana
  1. 启动容器
shell 复制代码
docker run  -d \
  -p 9090:9090 \
  -v /opt/prometheus/prometheus.yml:/etc/prometheus/prometheus.yml  \
  --name prometheus \
  prom/prometheus
  1. 配置数据源

  1. 配置mysql监控面板





最终效果如下:

  1. 配置linux监控面板

与mysql配置基本一样,只有模版ID变了,为12633。效果如下图:

相关推荐
MonkeyKing_sunyuhua3 分钟前
ubuntu22.04 docker-compose安装postgresql数据库
数据库·docker·postgresql
掘金-我是哪吒34 分钟前
微服务mysql,redis,elasticsearch, kibana,cassandra,mongodb, kafka
redis·mysql·mongodb·elasticsearch·微服务
追风林35 分钟前
mac m1 docker本地部署canal 监听mysql的binglog日志
java·docker·mac
zmgst2 小时前
canal1.1.7使用canal-adapter进行mysql同步数据
java·数据库·mysql
令狐少侠20112 小时前
explain执行计划分析 ref_
mysql
随心............2 小时前
python操作MySQL以及SQL综合案例
数据库·mysql
€☞扫地僧☜€2 小时前
docker 拉取MySQL8.0镜像以及安装
运维·数据库·docker·容器
茶馆大橘2 小时前
微服务系列六:分布式事务与seata
分布式·docker·微服务·nacos·seata·springcloud
xjjeffery2 小时前
MySQL 基础
数据库·mysql
恒辉信达2 小时前
hhdb数据库介绍(8-4)
服务器·数据库·mysql