部署Prometheus+Grafana监控平台实践

 更新时间:2026年01月26日 09:25:06   作者:ICT董老师  
文章介绍了如何在宿主机上配置Prometheus和Grafana,并使用NodeExporter监控Linux服务器,通过Docker部署Prometheus和Grafana,并在Prometheus中添加NodeExporter作为数据源,最后,通过Grafana导入仪表盘来可视化监控数据

可视化监控方案

在宿主机上编写Prometheus配置文件

mkdir /etc/prometheus
vi /etc/prometheus/prometheus.yml

文件配置内容如下:

global:
  scrape_interval: 15s
  evaluation_interval: 15s
alerting:
  alertmanagers:
    - static_configs:
      - targets:
        # - alertmanager:9093
rule_files:
  # - "first_rules.yml"
  # - "second_rules.yml"
scrape_configs:
  - job_name: "prometheus"
    static_configs:
      - targets: ["localhost:9090"]

使用Docker创建Prometheus容器

docker network create monitoring
docker run -d --name=prometheus --net=monitoring -v /etc/prometheus:/etc/prometheus/ -v prometheus-data:/prometheus -p 9090:9090 prom/prometheus:latest

在浏览器中访问“http://<宿主机IP地址>:9090”,可以看到Prometheus的首页。

使用Docker部署Grafana

docker run -d --name=grafana --net=monitoring -v grafana-data:/var/lib/grafana -p 3000:3000 grafana/grafana:latest

在浏览器中访问“http://<宿主机IP地址>:3000”,可以看到Grafana登陆页面,默认用户名和密码均为“admin”,第一次登陆需设置新的密码。然后进入Grafana首页。

在Grafana中添加Prometheus作为数据源

DATA SOURCES->Add your first data source->Prometheus,进入数据源配置页面,在Connection中Prometheus server URL输入Prometheus的访问地址“http://<宿主机IP地址>:9090”,单击Save&test按钮进行保存和测试。添加成功后,可以在Connections中的Data sources查看数据源。

Prometheus监控案例–监控Linux服务器

Node Exporter用于采集和暴露本机的系统性能数据,包括但不限于CPU、内存、硬盘、网络接口等指标。

在监控主机上部署Node Exporter

Node Export支持多种安装方式,包括Docker和二进制。如果目标监控主机已安装Docker,则建议使用Docker容器部署;反之,则使用二进制的方式部署。

下面演示通过二进制方式部署:

在官网上下载Node Exporter安装包

wget https://github.com/prometheus/node_exporter/releases/download/v1.10.2/node_exporter-1.10.2.linux-amd64.tar.gz
tar zxvf node_exporter-1.10.2.linux-amd64.tar.gz
mv node_exporter-1.10.2.linux-amd64 /usr/local/node_exporter

使用Systemd管理node_exporter程序,创建服务文件

vi /usr/lib/systemd/system/node_exporter.service

文件配置内容如下:

[Unit]
Description=Prometheus Node Exporter
After=network.target
[Service]
Type=simple
User=nobody
Group=nobody
ExecStart=/usr/local/node_exporter/node_exporter
Restart=always
RestartSec=10
[Install]
WantedBy=multi-user.target

启动并设置开机启动

#  重新加载 systemd
systemctl daemon-reload
#  重置失败计数器
systemctl reset-failed node_exporter
#  禁用SELinux
setenforce 0
#  启动服务
systemctl start node_exporter
#  开机启动
systemctl enable node_exporter

Node Exproter默认监听9100端口,可以通过浏览器访问被监控服务器“http://192.168.1.76:9100/metrics”查看采集的指标数据。

Prometheus添加监控目标

为了将上面的被监控Linux服务器加入Prometheus监控中,需要在Prometheus配置文件(/etc/prometheus/prometheus.yml)中添加监控目标,配置如下

vi /etc/prometheus/prometheus.yml
global:
  scrape_interval: 15s
  evaluation_interval: 15s
alerting:
  alertmanagers:
    - static_configs:
      - targets:
        # - alertmanager:9093
rule_files:
  # - "first_rules.yml"
  # - "second_rules.yml"
scrape_configs:
  - job_name: "prometheus"
    static_configs:
      - targets: ["localhost:9090"]
  - job_name: "Linux-Server"
    # metrics_path: '/metrics'
    # scheme: http
    static_configs:
      - targets: ["192.168.1.75:9100","192.168.1.76:9100"]

配置完成后,重启Prometheus容器或者向Prometheus进程发送“SIGHUP”信号以重新加载配置文件:

docker exec -it prometheus kill -HUP 1

在浏览器中访问“http://<宿主机IP地址>:9090”,打开Prometheus的页面,单击导航栏中的“Status->Target health”,可以看到被监控的服务器状态为“UP”,表明已成功监控。

Prometheus会定期收集从“Endpoint”显示的地址中获取指标数据并对该数据进行存储。在页面导航栏“Graph”中,可以使用PromQL查询语句检索存储在Prometheus中的指标数据。

例如,查看与CPU相关的指标,输入“node_cpu_seconds_total{instance=“192.168.1.75:9100”}”即可查询。

Grafana导入仪表盘

在浏览器中访问“http://<宿主机IP地址>:3000”,进入Grafana页面,按以下方式配置:

home->Dashboards->Create dashboard->import dashboard输入仪表盘ID"12633",单击Load按钮加载,进入仪表盘配置界面,在这里设置仪表盘的名称和Prometheus数据源,单击Import完成导入,将看到仪表盘界面。

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

相关文章

  • docker容器访问宿主机的MySQL操作

    docker容器访问宿主机的MySQL操作

    这篇文章主要介绍了docker容器访问宿主机的MySQL操作,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2021-03-03
  • Docker中容器数据卷详解

    Docker中容器数据卷详解

    这篇文章主要介绍了Docker中容器数据卷详解的相关资料,需要的朋友可以参考下
    2022-11-11
  • spring-boot构建docker镜像上传仓库的示例教程

    spring-boot构建docker镜像上传仓库的示例教程

    这篇文章主要介绍了spring-boot构建docker镜像上传仓库,受限创建一个简单spring-boot-web项目,查看镜像上传仓库这时候有两种解决方案,对docker镜像上传仓库相关知识感兴趣的朋友跟随小编一起看看吧
    2022-12-12
  • zabbix监控docker容器状态【推荐】

    zabbix监控docker容器状态【推荐】

    这篇文章主要介绍了zabbix监控docker容器状态的相关资料,非常不错,具有一定的参考借鉴价值,需要的朋友可以参考下
    2018-06-06
  • docker的harbor仓库登录问题小结

    docker的harbor仓库登录问题小结

    在使用Docker Harbor时,可能会因为证书信任问题或DNS解析问题导致登录失败,解决方法包括将自签名证书添加到系统的可信证书存储中,本文给大家介绍docker的harbor仓库登录问题,感兴趣的朋友一起看看吧
    2024-09-09
  • 简述Docker安装Tomcat镜像并部署web项目

    简述Docker安装Tomcat镜像并部署web项目

    这篇文章主要介绍了简述Docker安装Tomcat镜像并部署web项目,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-10-10
  • Docker镜像上传到阿里云的步骤详解

    Docker镜像上传到阿里云的步骤详解

    本篇文章主要介绍了Docker镜像上传到阿里云的步骤详解,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2017-09-09
  • Docker报错denied:requested access to the resource is denied解决

    Docker报错denied:requested access to the r

    这篇文章主要为大家介绍了Docker报错denied:requested access to the resource is denied解决方法详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-06-06
  • Docker如何快速搭建LNMP环境(最新)

    Docker如何快速搭建LNMP环境(最新)

    Docker 是一个开源的应用容器引擎,基于 Go 语言 并遵从Apache2.0协议开源。本文给大家分享机器学习的基础知识,docker搭建lnmp环境的步骤,感兴趣的朋友一起看看吧
    2021-06-06
  • docker 安装nacos并配置数据库的教程详解

    docker 安装nacos并配置数据库的教程详解

    这篇文章主要介绍了docker 安装nacos并配置数据库的教程详解,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2020-12-12

最新评论