元标签

在被监控端纳入普罗米修斯里面定义了一些元数据标签
在Prometheus所有的Target实例中,都包含一些默认的Metadata标签信息。可以通过Prometheus UI的 Status 里面的 Service Discovery 查看

Metadata标签 说明
address 当前Target实例的访问地址 host:port
scheme 采集目标服务访问地址的HTTP Scheme,HTTP或者HTTPS
metrics_path 采集目标服务访问地址的访问路径

上面这些标签将会告诉Prometheus如何从该Target实例中获取监控数据。除了这些默认的标签以外,我们还可以为Target添加自定义的标签。

元标签是不会写到数据库当中的,使用promql是查询不到这些标签的,如果需要源标签的数据(比如k8s部署的Prometheus使用自动发现获取pod监控),这个时候就需要把一些元标签重新打标签来使用。

比如上图,监控k8s的pod状态, 因为pod是动态的,所以需要pod名字和pod的namespace信息,就可以从元标签中取值。

自定义标签

可以针对特定的标签去查询,比如根据厂商、项目等来区分。

1
2
3
4
5
6
7
8
9
10
11
12
13
- job_name: 'Beijing Linux Server'
static_configs:
- targets: ['192.168.179.99:9100']
labels:
address: beijing
project: mysql

- job_name: 'Shanghai Linux Server'
static_configs:
- targets: ['192.168.179.99:9100']
labels:
address: shanghai
project: www

重新标记标签

action 重新标记标签动作, 可以取的值有:

动作 作用
replace 默认,通过regex匹配source_label的值,使用replacement来引用表达式匹配的分组,分组使用$1,$2…引用(正则匹配,提取字段创建新标签)
keep 删除regex与连接不匹配的目标 source_labels , keep drop就是让普罗米修斯采集和不采集哪些目标
drop 删除regex与连接匹配的目标 source_labels
labeldrop 删除regex匹配的标签
labelkeep 删除regex不匹配的标签
labelmap 匹配regex所有标签名称,并将捕获的内容分组,用第一个分组内容作为新的标签名(使用正则提取出多个字段,使用匹配到的作为新标签名,但是标签的内容不会改变,相对于对原有标签换了个名字)

举例

动态生成添加标签(对已有的标签重新标记)

1
2
3
4
5
6
7
8
9
- job_name: 'Linux Server'
static_configs:
- targets: ['192.168.179.99:9100']
metric_relabel_configs:
- action: replace
source_labels: ["instance"]
regex: (.*):([0-9]+) # 正则匹配标签值,( )分组
replacement: $1 # 引用分组匹配的内容
target_label: "ip"

可以看到该标签已经进入数据库里面了,这样就根据源标签通过正则匹配动态生成了新的标签

选择采集的目标

1
2
3
4
5
6
7
- job_name: 'Linux Server'
static_configs:
- targets: ['192.168.179.99:9100']
relabel_configs:
- action: drop
regex: "192.168.179.99:9100" # 正则匹配标签值
source_labels: ["_address_"]

在target里面就没有了,在普罗米修斯里面就看不到该台机器,同时exporter也不会被停止.

删除标签

有些标签不希望被存储上,那么可以使用 labeldrop, 删除regex匹配的标签去完成不需要入库 将里面的标签删除掉,在入库之前删除

1
2
3
4
5
6
- job_name: 'Linux Server'
static_configs:
- targets: ['192.168.179.99:9100']
relabel_configs:
- action: labeldrop
regex: "job" #正则匹配标签名称

keep

Keep只有匹配的才会去采集数据,不匹配的就不采集。下面意思就是pod当中有些注解中声明了prometheus_io_scrape这个字段,那么就会把你纳入监控,如果没有声明就不会纳入监控。也就是k8s当中部署了这么多pod,谁要监控,谁不要被监控,在部署service可以指定是否需要采集,如果需要采集需要在注解当中声明prometheus_io_scrape: true

在 service 里面声明配置注解,那么就会采集注解里面含有这个值的

1
2
annotations:
prometheus.io/scrape: 'true'
1
2
3
4
# 带注解  prometheus.io/scrape: true  的才会被采集,不然不采集,不入库
- source_labels: [__meta_kubernetes_service_annotation_prometheus_io_scrape]
action: keep
regex: true

replace

处理监控pod连接的ip地址,api接口,还有协议都需要重新标记默认的字段

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
# 重命名采集目标协议
- action: replace
regex: (https?)
source_labels:
- __meta_kubernetes_service_annotation_prometheus_io_scheme
target_label: __scheme__
# 重命名采集目标指标URL路径
- action: replace
regex: (.+)
source_labels:
- __meta_kubernetes_service_annotation_prometheus_io_path
target_label: __metrics_path__
# 重命名采集目标地址
- action: replace
regex: ([^:]+)(?::\d+)?;(\d+)
replacement: $1:$2
source_labels:
- __address__
- __meta_kubernetes_service_annotation_prometheus_io_port
target_label: __address__

这里就可以使用新的标签kubernetes_namespace在promql里面基于命名空间这个标签去查询了,因为 __meta_kubernetes_namespace这个标签是不会被存储的

1
2
3
4
5
# 生成命名空间标签
- action: replace
source_labels:
- __meta_kubernetes_namespace
target_label: kubernetes_namespace
1
2
3
4
5
6
# 修改NodeIP:10250为APIServerIP:6443
- action: replace
regex: (.*)
source_labels: ["__address__"] 源标签配匹为address
target_label: __address__
replacement: 192.168.31.61:6443

labelmap

做上面这些事情是有两个阶段的,一个是采集之前,一个是采集之后,如果在采集之前重新定义标签没生效,那么可以使用采集之后的标签(因为使用的是k8s的服务发现,不管用的是哪个服务发现,默认带的都是源标签__meta_kubernetes_node_label 比如consul那么就是以consul开头的,这些不同服务发现的标签就是为了新标签的生成,就是为了更加好的标识监控指标,源标签是不会入库的)

1
2
3
4
relabel_configs:
# 将标签(.*)作为新标签名,原有值不变(新的标签名字会被入库查询)
- action: labelmap
regex: __meta_kubernetes_node_label_(.*)

(.) 以其开头所有值匹配到,用这个匹配的值作为新的标签名字,新的标签名字就可以入库,就会被查询,因为元标签以下划线开头的是不会入库的,后面是用不了的/这样做的目的就是将后面(.)匹配的值作为一个新标签,并且将原有值赋予新标签,后面可以基于这个新标签查询数据了

原文链接:https://blog.csdn.net/qq_34556414/article/details/113503945