prometheus基于consul的服务发现

consul在微服务中用于服务注册与发现的,在prometheus中也可以用于被监控对象的自动发现,这样就实现了在不修改prometheus配置文件、不重启的情况下,自动发现exporter并将其加入到监控范围

运行consul

可以去官网下载二进制安装包,但这里我还是推荐使用docker,快速上手
docker run -d --rm --name=consul -p 8500:8500 consul:1.15.4

浏览器访问 IP:8500 到consul的services页面,可见现在只有一个consul服务:

运行prometheus

修改默认配置文件为如下内容:

yaml 复制代码
# ...
scrape_configs:
  - job_name: "prometheus"

# 注释掉之前静态配置的内容
#    static_configs:
#      - targets: ["localhost:9090"]

# 修改服务发现为 consul_sd_configs:
	consul_sd_configs:
	- server: 'consul_ip:8500'
	  services: ['node_exporter']

启动prometheus容器:
docker run -d -p 9090:9090 -v $(pwd)/prometheus.yml:/opt/bitnami/prometheus/conf/prometheus.yml --name prometheus --rm bitnami/prometheus

浏览器访问 IP:9090 到prometheus的targets页面,目前也是一个target都没有

将node_exporter注册到consul

这里采用发HTTP请求的方式注册.先写一个注册的shell脚本

register_consul.sh:

shell 复制代码
#!/bin/bash
NodeExporterIP=""
NodeExporterPort=9200
ServiceID="node_exporter1"  # 服务唯一标记,随便写,只要保证唯一就行,一般是uuid
ServiceName="node_exporter"  # (一组)服务的名称

consulIP=""
consulPort=8500

curl -X PUT -d '{
  "id": "'$ServiceID'",
  "name": "'$ServiceName'",
  "address": "'$NodeExporterIP'",
  "port": '$NodeExporterPort',
  "tags": ["node_exporter"],
  "checks": [
    {
      "http": "http://'$NodeExporterIP':'$NodeExporterPort'/metrics",
      "interval": "10s"
    }
  ]
}' http://$consulIP:$consulPort/v1/agent/service/register

注册脚本可以写到node_exporter的启动脚本中(比如systemctl的service或者单独的shell脚本),这样就能在node_exporter启动时,自动注册到consul

运行脚本后到consul和prometheus页面上就能发现刚刚注册的服务和target:

注销服务脚本,deregister_consul.sh:

shell 复制代码
#!/bin/bash
ServiceID="node_exporter1"

consulIP=""
consulPort=8500

curl -X PUT http://$consulIP:$consulPort/v1/agent/service/deregister/$ServiceID

服务从consul注销后,prometheus也会自动将其从targets中移除

相关推荐
码农小卡拉2 天前
Prometheus 监控 SpringBoot 应用完整教程
spring boot·后端·grafana·prometheus
牛奶咖啡132 天前
Prometheus+Grafana构建云原生分布式监控系统(十五)_Prometheus中PromQL使用(二)
云原生·prometheus·集合运算·对查询结果排序·直方图原理·统计掉线的实例·检查节点或指标是否存在
没有bug.的程序员3 天前
Spring Cloud Alibaba:Nacos 配置中心与服务发现的工业级深度实战
java·spring boot·nacos·服务发现·springcloud·配置中心·alibaba
牛奶咖啡133 天前
Prometheus+Grafana构建云原生分布式监控系统(十四)_Prometheus中PromQL使用(一)
云原生·prometheus·promql·计算一个时间范围内的平均值·将相同数据整合查看整体趋势·计算时间范围内的最大最小比率·向量标量的算术运算
牛奶咖啡134 天前
Prometheus+Grafana构建云原生分布式监控系统(十三)_Prometheus数据模型及其PromQL
云原生·prometheus·prometheus数据类型·promql使用场景·promql表达式解析·promql数据类型·监控系统的方法论与指标
AC赳赳老秦5 天前
外文文献精读:DeepSeek翻译并解析顶会论文核心技术要点
前端·flutter·zookeeper·自动化·rabbitmq·prometheus·deepseek
九皇叔叔6 天前
【04】微服务系列 之 Nacos 注册中心(服务发现)
java·微服务·nacos·服务发现
牛奶咖啡136 天前
Prometheus+Grafana构建云原生分布式监控系统(十二)_基于DNS的服务发现
云原生·prometheus·dns·搭建自己的dns服务器·使用bind搭建dns服务器·配置正向解析·基于dns的服务发现
A-刘晨阳7 天前
Prometheus + Grafana + Alertmanager 实现邮件监控告警及配置告警信息
运维·云计算·grafana·prometheus·监控·邮件
饺子大魔王的男人7 天前
告别服务器失联!Prometheus+Alertmanager+cpolar 让监控告警不局限于内网
运维·服务器·prometheus