如何向 Prometheus Gauge 添加更多信息?

How to add more information to Prometheus Gauge?

我想使用 Prometheus 监控不同命名空间中 运行 in pods 的不同子进程的统计信息,我正在寻找一种正确公开此信息的方法。

我的集群与下面类似:

cluster
├── ns1
│   ├── ns1-pod1
│   │   ├── proc-p1-1
│   │   └── proc-p1-2
│   └── ns1-pod2
│       ├── proc-p2-1
│       └── proc-p2-2
└── ns2
    ├── ns2-pod1
    │   ├── proc-p1-1
    │   └── proc-p1-2
    └── ns2-pod2
        ├── proc-p2-1
        └── proc-p2-2

每个 pod 使用特定的路由键将其进程的统计信息发布到 RabbitMQ,我可以从那里读取统计信息。

我写了一个可以连接到一个命名空间中的 RMQ 的导出器,读取统计信息并将它们公开在 /metrics 上,以便 Prometheus 可以读取它。我的出口商的一个例子:

// prometheus go client
var MemoryValue = prometheus.NewGauge(
    prometheus.GaugeOpts{
        Namespace: namespace,
        Name:      "MemoryValue",
        Help:      "MemoryValue",
    })

prometheus.MustRegister(MemoryValue)
MemoryValue.Set(opst.Memory.Value) // "opst.Memory.Value" is what I get from RMQ

问题是我不知道如何标记 pod 中每个进程的指标。我的意思是,例如,目前我在 ns1 中有 4 个进程,但我将所有进程都暴露在 MemoryValue 上。我需要一种类似于 Namespace 的方法来按 pod 和进程名称标记每个进程(我有这些信息,但如何将它们添加到 Prometheus?)。

正如@Peter 正确提到的那样,解决方案是使用 GaugeVec:

var CpuPercentValue = prometheus.NewGaugeVec(
    prometheus.GaugeOpts{
        Namespace: "MyExporter",
        Name:      "CpuPercentValue",
        Help:      "CpuPercentValue",
    },
    []string{
        "namespace",
        "proc_qID",
        "opID",
    },
)

CpuPercentValue.With(prometheus.Labels{"namespace": namespace, "proc_qID": procid, "opID": opid}).Set(opst.CpuPercent.Value)