Golang中耗时统计监控

定义prometheus统计变量

import "github.com/prometheus/client_golang/prometheus"

var XXXCost          prometheus.Histogram

func init() {
    XXXCost = prometheus.NewHistogram(
        prometheus.HistogramOpts{
            Namespace: namespace,
            Subsystem: subsystem,
            Name:      "xxx_duration_seconds",
            Help:      "the cost of xxx",
        },
        []string{"labelname"},
    )
    prometheus.MustRegister(XXXCost)
}

细节:

  1. 注册的时候可以通过 NamespaceSubsystem 指定不同的命名空间。
  2. 注册的Name中注明统计的时间单位是秒。
  3. 还可以增加labelname区分不同的处理逻辑

在代码中统计耗时

start := time.Now()
// 待统计代码
cost := time.Since(start)
XXXCost.WithLabelValues("labelvalue").Observe(cost.Seconds())

细节:

  1. time.Duration.Seconds()返回值是float64,也就是说它会将小于一秒的时间作为小数返回。
  2. 通过使用 WithLabelValues 指定对应的label内容

在grafana中查询

在Grafana中可以通过如下的查询语句统计耗时

sum(rate(namespace_subsystem_xxx_duration_seconds_sum{job="job"}[20s])/rate(namespace_subsystem_xxx__seconds_count{job="job"}[20s])) by (instance)

细节:

  1. 计算rate的时候需要保证在这个区间至少有两个采集点。
  2. 通过 sum * by * 的方式可以汇总不同内容的统计结果

Grafana的配置

Grafana的配置中通过指定Legend format ,展示关键字段
在这里插入图片描述
通过如下路径配置耗时单位,本例中为秒。
在这里插入图片描述
在这里插入图片描述

  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值