5

我有以下时间序列条目。

ifDescr{ifDescr="GigabitEthernet1/1",ifIndex="1",instance="x.x.x.x",job="snmp"} 1
ifDescr{ifDescr="GigabitEthernet1/2",ifIndex="2",instance="x.x.x.x",job="snmp"} 1
ifDescr{ifDescr="GigabitEthernet5/3",ifIndex="3",instance="x.x.x.x",job="snmp"}
ifHCInOctets{ifIndex="1",instance="x.x.x.x",job="snmp"}
ifHCInOctets{ifIndex="2",instance="x.x.x.x",job="snmp"}
ifHCInOctets{ifIndex="2",instance="x.x.x.x",job="snmp"}

事实上,我无法判断哪个索引与哪个描述匹配,这让事情变得混乱。

有没有办法基本上将上述标签ifIndex与 ifDesc 标签相关联?或者也许这项工作可以用来将两个时间序列联系在一起?

我已经查看了该group_left功能,但无法弄清楚如何使其工作以组合/聚合标签。

4

1 回答 1

7

在这种情况下,您想要类似的东西rate(ifHCInOctets[5m]) * ignoring(ifDescr) group_left(ifDescr) ifDescr

解释:

Prometheus 只允许您在系列之间的操作上使用分组。的值ifDescr始终为“1”,因此相乘是安全的。

ignoring子句意味着不要使用ifDescr标签进行匹配(因为它只在一个系列上)。ifIndex,instance并将job被使用。

group_left正在指定您想要从系列中获得哪些标签ifDescr。在这种情况下,它们具有相同的名称。

<vector expr> <bin-op> ignoring(<label list>) group_left(<label list>) <vector expr>

参考: https ://prometheus.io/docs/prometheus/latest/querying/operators/#many-to-one-and-one-to-many-vector-matches

于 2018-05-14T21:30:29.593 回答