Prometheus重新标记
Prometheus重新标记
一、背景
我们知道prometheus
是一个时间序列数据库。会周期性的从各个target
上抓取数据。那么我们抓取回来的各种指标数据,我们有没有办法再次进行处理呢?
比如:
1、添加或删除某些不必要的标签。
2、从指标中删除敏感或不需要的标签。
3、修改标签的名字或标签的值等。
要实现上述功能,我们就需要对标签进行重新标记
。
通过重新标记
,我们可以控制、管理并标准化环境中的指标。
二、简化的指标抓取的生命周期
从上图中可知,我们有2个阶段(relable_configs
和metric_relabel_configs
)可以进行重新标记。
1、配置参数详解
# 从已有的标签选择值的源标签组;多个标签,使用separator分隔;
# regex匹配源标签里的值
[ source_labels: '[' <labelname> [, ...] ']' ]
# 多个 source_labels 时以这个连接起来
[ separator: <string> | default = ; ]
# 替换成的目标标签,可以使用正则中的分组
[ target_label: <labelname> ]
# 正则表达式匹配标签中的值
[ regex: <regex> | default = (.*) ]
# Modulus to take of the hash of the source label values.
[ modulus: <int> ]
# 替换正则表达式匹配的分组,分组引用使用 $1,$2,$3
[ replacement: <string> | default = $1 ]
# 正则表达式匹配后执行的动作
[ action: <relabel_action> | default = replace ]
1、action:
存在的值
1、替换标签值
replace:
首先将source_labels
中指定的各标签的值以separator
进行连接起来,然后将regex
字段中的正则标签是对连接起来的标签值进行匹配判定,如果匹配上了,则将target_label
字段中指定的标签的值替换为replacement
字段中保存的值。hashmod:
将target_label
的值设置为一个hash值,该hash则由modules
字段指定的hash模对source_labels
上各标签的串联值进行hash计算生成。
2、删除指标
keep:
使用regex
不能匹配到target
上的source_labels
上的各标签的串联值时,则删除该target
。drop:
使用regex
能匹配到target
上的source_labels
上的各标签的串联值时,则删除该target
。
3、创建或删除标签
lablemap:
将regex
对所有的标签名进行匹配判定,而后将匹配到的标签的值赋给replacement
字段指定的标签名之上。通常用于生成一个新的标签。labeldrop:
将regex
对所有的标签名进行匹配判断,能够匹配到的标签从该target
的标签集中删除。labelkeep:
将regex
对所有的标签名进行匹配判断,不能够匹配到的标签从该target
的标签集中删除。
2、删除标签注意事项
标签
是时间序列
的唯一性约束
。如果删除标签或重命名标签并导致时间序列重复,那么系统 可能会出现问题。
3、几个系统内置的标签
__address__:
当前Target实例的访问地址:。
__scheme__:
采集目标服务访问地址的HTTP Scheme,HTTP或者HTTPS。
__metrics_path__:
采集目标服务访问地址的访问路径。
__param_<name>:
采集任务目标服务的中包含的请求参数。
__name__:
此标签是标识指标名称的预留标签。
1、relable_configs 阶段
该阶段发生在指标抓取之前,即来自服务发现的目标。
**示例:**将__scheme__、__address__和__metrics_path__标签对应的值连接起来,判断是否是以(http或https)开头,如果是,则将 instance 标签对应的值修改成正确匹配的值。
scrape_configs:
- job_name: 'prometheus'
static_configs:
- targets: ['localhost:9080']
relabel_configs:
- source_labels: ["__scheme__","__address__","metrics_path__"]
regex: "(http|https)(.*)"
separator: ""
target_label: "instance"
replacement: "${1}://${2}"
action: replace
2、metric_relable_configs 阶段
该阶段发生在指标抓取之后且数据没有保存到系统之前。
**示例:**删除go_info标签
三、参考文档
1、https://prometheus.io/docs/prometheus/latest/configuration/configuration/#relabel_config
Prometheus重新标记的更多相关文章
- 阿里云上万个 Kubernetes 集群大规模管理实践
点击下载<不一样的 双11 技术:阿里巴巴经济体云原生实践> 本文节选自<不一样的 双11 技术:阿里巴巴经济体云原生实践>一书,点击上方图片即可下载! 作者 | 汤志敏,阿里 ...
- Prometheus 系统监控方案 一
最近一直在折腾时序类型的数据库,经过一段时间项目应用,觉得十分不错.而Prometheus又是刚刚推出不久的开源方案,中文资料较少,所以打算写一系列应用的实践过程分享一下. Prometheus 是什 ...
- [系统集成] 部署 mesos-exporter 和 prometheus 监控 mesos task
前几天我在mesos平台上基于 cadvisor部署了 influxdb 和 grafana,用于监控 mesos 以及 docker app 运行信息,发现这套监控系统不太适合 mesos + do ...
- Prometheus(转载)
Prometheus 系统监控方案 一 https://www.cnblogs.com/vovlie/p/Prometheus_CONCEPTS.html 最近一直在折腾时序类型的数据库,经过一段时间 ...
- prometheus 标签使用
标签的配置使用 考虑到要明智地使用标签,我们需要给事物重新命名.在一个集中的.复杂的监视环境中,我们有时无法控制正在监视的所有资源以及它们公开的监视数据.重新标记允许在自己的环境中控制.管理和潜在地标 ...
- Prometheus监控学习笔记之Prometheus从1.x升级到2.x
详细参考这篇文章 https://cloud.tencent.com/developer/article/1171434 prometheus 2.0于2017-11-08发布,主要是存储引擎进行了优 ...
- Go语言开发Prometheus Exporter示例
一.Prometheus中的基本概念 Prometheus将所有数据存储为时间序列,这里先来了解一下prometheus中的一些基本概念 指标名和标签每个时间序列都由指标名和一组键值对(也称为标签)唯 ...
- TiKV 源码解析系列文章(三)Prometheus(上)
本文为 TiKV 源码解析系列的第三篇,继续为大家介绍 TiKV 依赖的周边库 rust-prometheus,本篇主要介绍基础知识以及最基本的几个指标的内部工作机制,下篇会介绍一些高级功能的实现原理 ...
- Prometheus监控学习笔记之初识PromQL
0x00 概述 Prometheus 提供了一种功能表达式语言 PromQL,允许用户实时选择和汇聚时间序列数据.表达式的结果可以在浏览器中显示为图形,也可以显示为表格数据,或者由外部系统通过 HTT ...
随机推荐
- Java-Bean Validation后端校验总结
Validation Information resource: SpringBoot Docs: 2.8.9. @ConfigurationProperties Validation url: ht ...
- redis存取数据Hash
一.概念 二.存取散列Hash值 1. 2.JSON字符串存取,没有更新值的字段资源浪费 使用散列Hash存取,可以单独到一个或多个字段: 3.hsetnx,属性不存在就新增并赋值,属性已存在啥也不干 ...
- MongoDB索引的简单理解
目录 MongoDB索引 1.语法准备 2.数据准备: 3.索引 3.1 唯一索引 3.2 单键索引 3.3 多键索引 3.4 复合索引 3.5 交叉索引 3.6 部分索引 3.7覆盖索引 3.8 全 ...
- Flex语法和常用鼠标手势
Flex弹性和模型 1.display : flex/inline-flex ;(设置给氟元素) flex : 将对象作为弹性伸缩盒显示: inline-flex : 将对象作为内联块级弹性伸缩显示: ...
- Vue组件传值(三)之 深层嵌套组件传值 - $attrs 和 $listeners
$attrs 包含了父作用域中不作为 prop 被识别 (且获取) 的特性绑定 (class 和 style 除外).当一个组件没有声明任何 prop 时,这里会包含所有父作用域的绑定 (class和 ...
- ThinkCMF5.1主要特性
更改框架协议为MIT,让你更自由地飞 基于ThinkPHP 5.1重构,但核心代码兼容5.0版本,保证老用户最小升级成本 增加对swoole支持,同时支持swoole协程和全同步模式(请单独安装扩展) ...
- Ubuntu管理员手册
hostname cat /etc/hosts apt-get install iproute2 iproute2-doc ip a ps -aux
- HDU - 3790 最短路径问题 (dijkstra算法)
HDU - 3790 最短路径问题 Description 给你n个点,m条无向边,每条边都有长度d和花费p,给你起点s终点t,要求输出起点到终点的最短距离及其花费,如果最短距离有多条路线,则输出花费 ...
- java线程day-02
1.什么是线程 * 线程是程序执行的一条路径, 一个进程中可以包含多条线程 * 多线程并发执行可以提高程序的效率, 可以同时完成多项工作 2.多线程的应用场景 * 红蜘蛛同时共享屏幕给多个电脑 * 迅 ...
- ECSHOP产品内容页新增上传功能
第一步:在 admin\templates\goods_info.htm中 <span class="tab-back" id="article-tab" ...