美文网首页Amazing Arch
让普罗米修斯替我监测树莓派集群

让普罗米修斯替我监测树莓派集群

作者: _黑冰_ | 来源:发表于2020-01-06 19:57 被阅读0次

背景

最近看着手里的几只树莓派在吃灰,心中不忍,遂想利用它们搭个小应用,并在新买的RPI4上监测他们的状态
以下过程参考了网上的文章,并使用了新版本的prometheus和Grafana搭配

过程

1、首先要在各监测点上安装node_exporter,由这个代理程序在各节点上采集设备信息

cd /home
curl -SL https://github.com/prometheus/node_exporter/releases/download/v0.16.0/node_exporter-0.16.0.linux-armv7.tar.gz > node_exporter.tar.gz && sudo tar -xvf node_exporter.tar.gz -C /usr/local/bin/ --strip-components=1

2、运行node_exporter

node_exporter

测试通过后可以配置supervisordsystemd等在后台运行,例如做为系统服务:

vim /etc/systemd/system/node_exporter.service

输入如下代码:

[Unit]
Description=Node Exporter
Wants=network-online.target
After=network-online.target

[Service]
User=root
ExecStart=/home/node_exporter

[Install]
WantedBy=default.target

开机启动

systemctl daemon-reload
systemctl status node_exporter
systemctl start node_exporter
systemctl enable node_exporter

3、在监测机上配置prometheus,将下面的配置保存到 prometheus.yml

# my global config
global:
  scrape_interval:     15s # Set the scrape interval to every 15 seconds. Default is every 1 minute.
  evaluation_interval: 15s # Evaluate rules every 15 seconds. The default is every 1 minute.
  # scrape_timeout is set to the global default (10s).

# Alertmanager configuration
alerting:
  alertmanagers:
  - static_configs:
    - targets:
      # - alertmanager:9093

# Load rules once and periodically evaluate them according to the global 'evaluation_interval'.
rule_files:
  # - "first_rules.yml"
  # - "second_rules.yml"

# A scrape configuration containing exactly one endpoint to scrape:
# Here it's Prometheus itself.
scrape_configs:
  # The job name is added as a label `job=<job_name>` to any timeseries scraped from this config.
  - job_name: 'prometheus'

    # metrics_path defaults to '/metrics'
    # scheme defaults to 'http'.

    static_configs:
    - targets: ['localhost:9090']
  - job_name: 'RPi_Mariadb'
    static_configs:
      - targets: ['192.168.10.10:9100']
  - job_name: 'RPi_Redis'
    static_configs:
      - targets: ['192.168.10.11:9100']
  - job_name: 'RPi_dotnet'
    static_configs:
      - targets: ['192.168.10.12:9100']

3、在树莓派上安装docker,通过脚本可以安装最新的docker

curl -sSL https://get.docker.com | sh

4、拉取prometheus镜象

docker pull prometheus

5、用上面的配置文件以及刚才拉取的镜象,创建一个新的镜象,这个镜象直接包含了我们的配置,当然,后面可以通过配置路径挂载,将配置文件保留在宿主机主,不用每次修改都要重新打包。

FROM prom/prometheus
COPY ./prometheus.yml /etc/prometheus/prometheus.yml

6、运行容器,prometheus通过9090端口提供一个WEB UI,UI上可以看到很多指标,但略丑。

docker run -p 9090:9090 --name prometheus-rpi -d prometheus/rpi-monitor

7、运行grafana

由于我这里安装的是32位的ARM,所以需要拉取32位的镜象,需要64位arm的朋友可以到hub.docker.com自行寻找相应的镜象

docker run -i -p 3000:3000 --name grafana6 grafana/grafana-arm32v7-linux:6.5.1

8、接下来就是配置datasource为prometheus,导入dashboard模板,模板ID为 8919,最终效果如下图

效果

参考文章

树莓派教程:使用监控系统 Prometheus 监控 Raspberry Pi 集群

【监控】Prometheus+Grafana监控简介

https://github.com/prometheus/node_exporter

相关文章

  • 让普罗米修斯替我监测树莓派集群

    背景 最近看着手里的几只树莓派在吃灰,心中不忍,遂想利用它们搭个小应用,并在新买的RPI4上监测他们的状态以下过程...

  • WGCLOUD支持监测windows吗

    支持的 支持监测Linux系列:Debian、RedHat、CentOS、ubuntu、麒麟、统信、>龙芯、树莓派...

  • IoT 边缘集群基于 Kubernetes Events 的告警

    背景 边缘集群(基于 树莓派 + K3S) 需要实现基本的告警功能。 边缘集群限制 CPU/内存/存储 资源紧张,...

  • 带你了解树莓派

    在本文中,你学到了树莓派是什么,它为什么存在,如何购买树莓派以及你需要哪些外设来让树莓派启动并运行。你知道了树莓派...

  • 树莓派终端代理

    树莓派安装Shadowsocks客户端 在树莓派上配置Shadowsocks客户端, 这是让树莓派翻QIANG的必...

  • 树莓派连接WiFi实现无线上网

    问题:我的树莓派怎么上网呢? 解答: 树莓派基金会于2016年2月发布了树莓派3,较前一代树莓派2,树莓派3的处理...

  • 如何用树莓派搭建一个颗粒物传感器

    用树莓派、一个廉价的传感器和一个便宜的屏幕监测空气质量。 大约一年前,我写了一篇关于如何使用树莓派和廉价传感器测量...

  • 树莓派针脚图

    树莓派40Pin引脚对照表 本表格适用于树莓派B+、树莓派2B、树莓派A+,并且兼容树莓派B,树莓派B为26Pin...

  • 树莓派上手资料

    树莓派开箱上手教程树莓派下载资料使用手机连接树莓派1使用手机连接树莓派2树莓派实验室无显示屏启动树莓派 如何用pu...

  • 如何让Android Things在树莓派3b上运行起来

    如何让Android Things在树莓派3b上运行起来 先来介绍一下树莓派,树莓派是在2012年开始发售的,主要...

网友评论

    本文标题:让普罗米修斯替我监测树莓派集群

    本文链接:https://www.haomeiwen.com/subject/intlactx.html