当前位置: 首页 > article >正文

pushgateway指标聚合问题

一 问题现象

一个job有多个实例推送指标,但是从pushgateway上看这个job的instance字段,只显示一个实例的ip,而不是多个实例。导致在grafana上无法正常根据ip查看监控。

在这里插入图片描述
应用的prometheus的配置

management:
  metrics:
    tags:
      application: ${spring.application.name}
    export:
      prometheus:
        pushgateway:
          #pushgateway地址
          baseUrl:  ***:9091
          #推送周期
          pushRate: 15s
          #job定义名
          job: ${spring.application.name}
          #启用推送
          enabled: true
  ## actuator暴露出prometheus
  endpoints:
    web:
      exposure:
        include: prometheus
  endpoint:
    health:
      show-details: always

二 解决办法

增加grouping-key,避免多个不同的实例的指标被聚合。HOSTNAME这个环境变量是k8s自带的

management:
  metrics:
    tags:
      application: ${spring.application.name}
    export:
      prometheus:
        pushgateway:
          #pushgateway地址
          baseUrl: ***:9091
          #推送周期
          pushRate: 15s
          #job定义名
          job: ${spring.application.name}
          #启用推送
          enabled: true
          grouping-key:
            hostname: ${HOSTNAME}
  ## actuator暴露出prometheus
  endpoints:
    web:
      exposure:
        include: prometheus,health
  endpoint:
    health:
      show-details: always

三 groupingkey作用分析

pushgateway指标上报的源码路径:io.prometheus.client.exporter.PushGateway#doRequest

没配置groupingkey的时候

在这里插入图片描述

配置了groupingkey的时候

在这里插入图片描述
由于是本机debug,HostName这个环境变量取不到,k8s上正常。

grouping-key 官方解释 https://github.com/prometheus/pushgateway

The default port the Pushgateway is listening to is 9091. The path looks like

      /metrics/job/<JOB_NAME>{/<LABEL_NAME>/<LABEL_VALUE>}

<JOB_NAME> is used as the value of the job label, followed by any number of other label pairs (which might or might not include an instance label). The label set defined by the URL path is used as a grouping key. Any of those labels already set in the body of the request (as regular labels, e.g. name{job=“foo”} 42) will be overwritten to match the labels defined by the URL path!

pushgateway是用请求pushgateway的url的path作为grouping-key的。如果不配置任何grouping-key,pushgateway会把所有job一样的指标聚合到一起


http://www.kler.cn/a/535730.html

相关文章:

  • 深度整理总结MySQL——SQL的执行顺序和流程
  • java基础2(黑马)
  • HTML学习笔记(6)
  • Qt:Qt环境配置安装
  • TCP连接管理与UDP协议IP协议与ethernet协议
  • 【论文精读】Taming Transformers for High-Resolution Image Synthesis
  • 动手学图神经网络(9):利用图神经网络进行节点分类 WeightsBiases
  • Vue2.7 如何使用Vue3新增的useStore、useRouter、useRoute
  • mysql mvcc 锁 关系
  • C语言:函数栈帧的创建和销毁
  • Windows图形界面(GUI)-QT-C/C++ - Qt QSpinBox
  • 16.状态模式(State Pattern)
  • arcgis for js范围内天地图高亮,其余底图灰暗
  • LLM驱动的NL2SQL方法论:现状、难点、优化
  • Less使用教程和步骤_less的使用
  • TfidfVectorizer
  • 若依框架使用(低级)
  • 软件工程导论三级项目报告--《软件工程》课程网站
  • TaskBuilder低代码开发项目实战—创建项目
  • 【数据科学】一个强大的金融数据接口库:AKShare
  • Blender 3D建模——AI脚本3D建模技巧
  • (五)QT——QDialog 对话框
  • 第八篇:数据库的安全性与权限管理
  • 求解大规模单仓库多旅行商问题(LS-SDMTSP)的成长优化算法(Growth Optimizer,GO),MATLAB代码
  • Android原生开发问题汇总
  • react使用DatePicker日期选择器