dpcyx08288 2016-06-03 10:18
浏览 1599
已采纳

如何使用client_golang将指标推送到Prometheus?

I have not yet able to find some good examples in using Gauge, Counter and Histogram in prometheus. Any help on this will do. I tried using the the documentation but I was not able to successfully create a working app.

  • 写回答

2条回答 默认 最新

  • douhuai2861 2016-06-03 10:40
    关注

    Prometheus is a pull-based system, if you want push-based monitoring, you need to use a gateway of some sort. A minimal example (without actually doing anything useful like starting an HTTP listener, or actually doing anything to a metric) follows:

    import (
            "github.com/prometheus/client_golang/prometheus"
            "net/http"
    )
    
    var responseMetric = prometheus.NewHistogram(
            prometheus.HistogramOpts{
                    Name: "request_duration_milliseconds",
                    Help: "Request latency distribution",
                    Buckets: prometheus.ExponentialBuckets(10.0, 1.13, 40),
            })
    
    func main() {
            prometheus.MustRegister(responseMetric)
            http.Handle("/metrics", prometheus.Handler())
            // Any other setup, then an http.ListenAndServe here
    }
    

    You then need to configure Prometheus to scrape the /metrics page your binary provides.

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

悬赏问题

  • ¥15 素材场景中光线烘焙后灯光失效
  • ¥15 请教一下各位,为什么我这个没有实现模拟点击
  • ¥15 执行 virtuoso 命令后,界面没有,cadence 启动不起来
  • ¥50 comfyui下连接animatediff节点生成视频质量非常差的原因
  • ¥20 有关区间dp的问题求解
  • ¥15 多电路系统共用电源的串扰问题
  • ¥15 slam rangenet++配置
  • ¥15 有没有研究水声通信方面的帮我改俩matlab代码
  • ¥15 ubuntu子系统密码忘记
  • ¥15 保护模式-系统加载-段寄存器