[基础服务] Grafana/Prometheus/node-exporter 的安装和部署

本文涉及的产品
可观测可视化 Grafana 版,10个用户账号 1个月
可观测监控 Prometheus 版,每月50GB免费额度
简介: [基础服务] Grafana/Prometheus/node-exporter 的安装和部署

简介

其实这种像Grafana 这种无状态应用非常适合使用docker来部署,后续扩展迁移可以完全保证环境的一致性。
下面我们使用docker快速部署一个Grafana 服务

监控端安装:
Prometheus Server(普罗米修斯监控主服务器 )
Node Exporter (收集Host硬件和操作系统信息)
cAdvisor (负责收集Host上运行的容器信息)
Grafana (展示普罗米修斯监控界面)

被监控安装:
Node Exporter (收集Host硬件和操作系统信息)
cAdvisor (负责收集Host上运行的容器信息)

方法 / 步骤

一: 安装 Grafana

🔗 Docker-Hub仓库

# 拉取最新 grafana:9.1.0版本
docker pull grafana/grafana:9.1.0

# 生成预配置
docker run -d \
--name grafana3000 \
-p 3000:3000 \
grafana/grafana:9.1.0
  • ip:3000端口打开

在这里插入图片描述

1.1: 配置文件进行挂载

docker cp grafana:/etc/grafana/. /docker/grafana3000/conf
docker cp grafana:/var/lib/grafana/. /docker/grafana3000/data
docker cp grafana:/var/log/grafana/. /docker/grafana3000/log 

1.2 编辑用户分组信息 (重要)

# 添加用户
useradd grafana

# 指定用户UID信息
vi /etc/passwd

--------- 官方约定grafana用户UID和GID都为472--------------
grafana:x:472:472::/home/grafana:/bin/bash
---------------------------------------------------------

# 编辑用户分组信息
vi /etc/group

---------------
grafana:x:472:
---------------



# 赋予账户权限
chown -R grafana:grafana  /docker/grafana3000
# 查看目录所属信息
ls -lhat /docker/grafana3000

官方文档链接
在这里插入图片描述

1.3 : 安装并检测

docker run -d \
--name grafana3000 \
-p 3000:3000 \
-v /docker/grafana3000/conf:/etc/grafana \
-v /docker/grafana3000/data:/var/lib/grafana \
-v /docker/grafana3000/log:/var/log/grafana \
-v /etc/localtime:/etc/localtime:ro \
--restart=always \
grafana/grafana:9.1.0

1.4 查看是否在运行:

docker ps -l

查看启动日志:

docker logs grafana3000 

如果没有启动成功的话,可以排查一下挂载的目录是否正确,比如是否配了目录权限等。

在这里插入图片描述
在这里插入图片描述

二: 部署并启动 Prometheus Server

Docker-Hub

# 选择最新2.38.0版本
docker pull prom/prometheus:v2.38.0

# 创建prometheus.yml文件
mkdir /docker/prometheus9090
cd /docker/prometheus9090
vim prometheus.yml
  • 编写yml文件 (一定要注意格式,否则会报错)
global:
  scrape_interval: 15s
  evaluation_interval: 15s
scrape_configs:
  - job_name: 'prometheus'
    static_configs:
    - targets: ['localhost:9090']
  • 运行
docker run -d \
--name=prometheus9090 \
-p 9090:9090 \
-v /docker/prometheus9090/prometheus.yml:/etc/prometheus/prometheus.yml \
--restart=always \
prom/prometheus:v2.38.0
  • 查看是否安装成功

http://ip:9090

在这里插入图片描述

  • 查看监控的数据

http://服务器IP:9090/metrics可以查看到监控的数据
在这里插入图片描述
在这里插入图片描述
下面就监控远程Linux主机, 在被监控端上安装node_exporter组件了

三: 部署并启动 node-exporter

不建议将其部署为Docker容器,因为它需要访问主机系统。请注意,您要监视的任何非根安装点都需要绑定到容器中。如果启动容器以进行主机监视,请指定path.rootfs参数。

Docker-Hub

# 拉取镜像(取最新稳定版本)
docker pull prom/node-exporter:v1.3.1

# node-expoter 默认端口号是9100
# 启动命令
docker run -d \
--net="host" \
--name node_exporter \
--restart=unless-stopped -p 9100:9100 \
-v "/proc:/host/proc:ro" \
-v "/sys:/host/sys:ro" \
-v "/:/rootfs:ro" \
--restart=always \
prom/node-exporter:v1.3.1

在这里插入图片描述

启动后通过
http://IP:9100/metrics 查看是否启动成功 (包含指标数据为启动成功)
在这里插入图片描述

五: 整合配置

5.1 到prometheus配置添加监控机器

# 更改配置文件
vi /docker/prometheus9090/prometheus.yml 

# job_name 给被监控主机取个名字,我这里直接填的IP
# targets 填写被监控主机的IP和端口
  - job_name: 'nasvm0-exporter'      
    static_configs:
    - targets: ['192.168.11.100:9100']

改完配置文件后,重启服务

docker restart  [CONTAINER ID]

打开prometheus

在这里插入图片描述

5.2 在Grafana上添加Prometheus 服务数据源

我们把prometheus服务器收集的数据做为一个数据源添加到grafana,让grafana可以得到prometheus的数据
在这里插入图片描述

在这里插入图片描述
在这里插入图片描述

  • 返回配置我们可以看到已经添加的数据源

在这里插入图片描述

5.3 Grafana图形显示Linux硬件信息

在🔗Grafana官方提供模板 中寻找 🔗 本次要导入的模板,该插件里面包含:CPU 内存 磁盘IO 网络, 温度和其他监控指标

在这里插入图片描述

  • 面板里面选择导入

在这里插入图片描述

在这里插入图片描述
将面板ID填入,选择数据源,点击导入

在这里插入图片描述

  • 导入成功

在这里插入图片描述

六: 监控报警

  • prometheus配合alertmanager这个组件报警,报警规则需要手动编写,这需要对prometheus+alertmanager有一定的了解
  • grafana配合SaaS模式的云告警平台onealert报警,onealert也是需要时间熟悉的
  • 这里演示最传统的grafana+email报警

6.1 修改grafana配置文件,添加发件邮箱

❗❗注意:如果smtp邮箱的25端口被禁用,如果出现发送超时可以改成465端口重试
🔗 相关邮箱服务地址查询


vi /docker/grafana3000/conf/grafana.ini
# 找到smtp关键字
#################################### SMTP / Emailing ##########################
[smtp]
enabled = true  # 改成true
host = smtp.exmail.qq.com:465   # 发送服务器地址和端口
user =   # 这里填写发件邮箱
# If the password contains # or ; you have to wrap it with triple quotes. Ex """#password;"""
password =  # 这里填写发件邮箱密码或授权密码
;cert_file =
;key_file =
skip_verify = true  # 改成true
from_address =  # 这里填写发件邮箱
;from_name = Grafana
# EHLO identity in SMTP dialog (defaults to instance_name)
;ehlo_identity = dashboard.example.com
# SMTP startTLS policy (defaults to 'OpportunisticStartTLS')
;startTLS_policy = NoStartTLS

6.2 在通知模块创建收件人组

在这里插入图片描述

  • 建立联系点

在这里插入图片描述

在这里插入图片描述
然后发送成功
在这里插入图片描述

参考资料 & 致谢

[1] Grafana监控

相关实践学习
通过可观测可视化Grafana版进行数据可视化展示与分析
使用可观测可视化Grafana版进行数据可视化展示与分析。
目录
相关文章
|
5天前
|
Prometheus 运维 监控
智能运维实战:Prometheus与Grafana的监控与告警体系
【10月更文挑战第26天】Prometheus与Grafana是智能运维中的强大组合,前者是开源的系统监控和警报工具,后者是数据可视化平台。Prometheus具备时间序列数据库、多维数据模型、PromQL查询语言等特性,而Grafana支持多数据源、丰富的可视化选项和告警功能。两者结合可实现实时监控、灵活告警和高度定制化的仪表板,广泛应用于服务器、应用和数据库的监控。
44 3
|
6天前
|
Prometheus 监控 Cloud Native
基于Docker安装Grafana和Prometheus
Grafana 是一款用 Go 语言开发的开源数据可视化工具,支持数据监控和统计,并具备告警功能。通过 Docker 部署 Grafana 和 Prometheus,可实现系统数据的采集、展示和告警。默认登录用户名和密码均为 admin。配置 Prometheus 数据源后,可导入主机监控模板(ID 8919)进行数据展示。
34 2
|
4天前
|
Prometheus 运维 监控
智能运维实战:Prometheus与Grafana的监控与告警体系
【10月更文挑战第27天】在智能运维中,Prometheus和Grafana的组合已成为监控和告警体系的事实标准。Prometheus负责数据收集和存储,支持灵活的查询语言PromQL;Grafana提供数据的可视化展示和告警功能。本文介绍如何配置Prometheus监控目标、Grafana数据源及告警规则,帮助运维团队实时监控系统状态,确保稳定性和可靠性。
21 0
|
2月前
|
Prometheus 监控 Cloud Native
prometheus学习笔记之node-export
prometheus 监控 node-exporter
|
2月前
|
JavaScript 应用服务中间件 Linux
宝塔面板部署Vue项目、服务端Node___配置域名
本文介绍了如何使用宝塔面板在阿里云服务器上部署Vue项目和Node服务端项目,并配置域名。文章详细解释了安装宝塔面板、上传项目文件、使用pm2启动Node项目、Vue项目打包上传、以及通过Nginx配置域名和反向代理的步骤。
366 0
宝塔面板部署Vue项目、服务端Node___配置域名
|
2月前
|
Prometheus 监控 Cloud Native
docker安装prometheus+Granfan并监控容器
【9月更文挑战第14天】本文介绍了在Docker中安装Prometheus与Grafana并监控容器的步骤,包括创建配置文件、运行Prometheus与Grafana容器,以及在Grafana中配置数据源和创建监控仪表盘,展示了如何通过Prometheus抓取数据并利用Grafana展示容器的CPU使用率等关键指标。
|
2月前
|
存储 Prometheus 监控
在Ubuntu系统上安装与配置Prometheus的步骤
通过以上步骤,您应该已经成功在Ubuntu系统上安装并配置了Prometheus。您现在可以开始使用Prometheus收集和分析您的系统和应用程序的指标数据了。
129 1
|
2月前
|
JavaScript Linux 开发工具
如何将nodejs项目程序部署到阿里云服务器上
该文章详细描述了将Node.js项目部署到阿里云服务器的步骤,包括服务器环境配置、项目上传及使用PM2进行服务管理的过程。
|
2月前
|
JavaScript 前端开发 Windows
NodeJS的环境部署
介绍如何在Windows操作系统上安装Node.js环境,包括下载长期支持版本的Node.js、安装程序、编写测试代码并执行,以及如何在WebStorm集成开发环境中配置和运行Node.js。
44 1
|
3月前
|
Prometheus 监控 Cloud Native
自定义grafana_table(数据源Prometheus)
综上所述,自定义 Grafana 表格并将 Prometheus 作为数据源的关键是理解 PromQL 的查询机制、熟悉 Grafana 面板的配置选项,并利用 Grafana 强大的转换和自定义功能使数据展示更为直观和有洞见性。随着对这些工具更深入的了解,您将可以创建出更高级的监控仪表盘,以支持复杂的业务监控需求。
225 1