登录
首页 >  Golang >  Go问答

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

来源:stackoverflow

时间:2024-04-30 09:45:38 182浏览 收藏

本篇文章主要是结合我之前面试的各种经历和实战开发中遇到的问题解决经验整理的,希望这篇《如何向 Prometheus Gauge 添加更多信息?》对你有很大帮助!欢迎收藏,分享给更多的需要的朋友学习~

问题内容

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

我的集群类似于下面:

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)

以上就是《如何向 Prometheus Gauge 添加更多信息?》的详细内容,更多关于的资料请关注golang学习网公众号!

声明:本文转载于:stackoverflow 如有侵犯,请联系study_golang@163.com删除
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>