动手写prometheus的exporter-02-Counter(计数器)

概述

  • 特点:只增不减(除非系统发生重启,或者用户进程有异常)。

常见的监控指标如http_requests_total, node_cpu都是Counter类型的监控指标。

  • 标记:一般以_total作为后缀。

1. 不带标签的Counter

1.1 定义指标

语法

  • 实例化
func NewCounter(opts CounterOpts) Counter
  • CounterOpts类型
type CounterOpts Opts
  • Opts结构体
type Opts struct {
    Namespace   string
    Subsystem   string
    Name        string
    Help        string
    ConstLabels Labels
}

完整示例

  • 代码
package main

import (
	"flag"
	"github.com/prometheus/client_golang/prometheus"
	"github.com/prometheus/client_golang/prometheus/promhttp"
	"log"
	"net/http"
	"time"
)

var addr = flag.String("listen-address", ":1840", "The address to listen on for HTTP requests")

var (
	numOfBuns = prometheus.NewCounter(prometheus.CounterOpts{
		Namespace: "xi_shu",
		Subsystem: "jing_zhou_team",
		Name:      "guanyu_eaten_num_all",
		Help:      "Number of steamed buns eaten by Guan Yu",
	})
)

func init() {
	prometheus.MustRegister(numOfBuns)
}

func main() {
	flag.Parse()
	http.Handle("/metrics", promhttp.Handler())
	log.Fatal(http.ListenAndServe(*addr, nil))
}

  • 结果显示
# HELP xi_shu_jing_zhou_team_guanyu_eaten_num Number of steamed buns eaten by Guan Yu
# TYPE xi_shu_jing_zhou_team_guanyu_eaten_num counter
xi_shu_jing_zhou_team_guanyu_eaten_num_all 0

1.2 获取数据

语法

  • Add() 增加N
func (Counter) Add(float64)
  • Inc() 增加1
func (Counter) Inc()

完整示例

package main

import (
	"flag"
	"github.com/prometheus/client_golang/prometheus"
	"github.com/prometheus/client_golang/prometheus/promhttp"
	"log"
	"net/http"
	"time"
)
var addr = flag.String("listen-address", ":1840", "The address to listen on for HTTP requests")

var (
	numOfBuns = prometheus.NewCounter(prometheus.CounterOpts{
		Namespace: "xi_shu",
		Subsystem: "jing_zhou_team",
		Name:      "guanyu_eaten_num_all",
		Help:      "Number of steamed buns eaten by Guan Yu",
	})
)

func init() {
	prometheus.MustRegister(numOfBuns)
}

func main() {
	flag.Parse()
	go func() {
		for true {
			numOfBuns.Add(2)
			time.Sleep(time.Second)
		}
	}()
	http.Handle("/metrics", promhttp.Handler())
	log.Fatal(http.ListenAndServe(*addr, nil))
}
  • 结果显示
# HELP xi_shu_jing_zhou_team_guanyu_eaten_num_all Number of steamed buns eaten by Guan Yu
# TYPE xi_shu_jing_zhou_team_guanyu_eaten_num_all counter
xi_shu_jing_zhou_team_guanyu_eaten_num_all 74

2. 带标签的Counter

2.1 定义指标

语法

  • 实例化
func NewCounterVec(opts CounterOpts, labelNames []string) *CounterVec
  • CounterOpts类型
type CounterOpts Opts
  • Opts结构体
type Opts struct {
    Namespace   string
    Subsystem   string
    Name        string
    Help        string
    ConstLabels Labels
}

完整示例

package main

import (
	"flag"
	"github.com/prometheus/client_golang/prometheus"
	"github.com/prometheus/client_golang/prometheus/promhttp"
	"log"
	"net/http"
	"time"
)
var addr = flag.String("listen-address", ":1840", "The address to listen on for HTTP requests")

var (
	numOfBuns = prometheus.NewCounterVec(prometheus.CounterOpts{
		Namespace: "xi_shu",
		Subsystem: "jing_zhou_team",
		Name:      "eaten_num_all",
		Help:      "Number of steamed buns eaten by Guan Yu",
	},[]string{"name","age"})
)

func init() {
	prometheus.MustRegister(numOfBuns)
}

func main() {
	flag.Parse()
	http.Handle("/metrics", promhttp.Handler())
	log.Fatal(http.ListenAndServe(*addr, nil))
}
  • 输出
    带标签的指标,没有打标签之前,不会显示。

2.2 获取数据

语法

  • Add() 增加N
func (Counter) Add(float64)
  • Inc() 增加1
func (Counter) Inc()

完整示例

  • 代码
package main

import (
	"flag"
	"github.com/prometheus/client_golang/prometheus"
	"github.com/prometheus/client_golang/prometheus/promhttp"
	"log"
	"net/http"
	"time"
)
var addr = flag.String("listen-address", ":1840", "The address to listen on for HTTP requests")

var (
	numOfBuns = prometheus.NewCounterVec(prometheus.CounterOpts{
		Namespace: "xi_shu",
		Subsystem: "jing_zhou_team",
		Name:      "eaten_num_all",
		Help:      "Number of steamed buns eaten by Guan Yu",
	},[]string{"name","age"})
)

func init() {
	prometheus.MustRegister(numOfBuns)
}

func main() {
	flag.Parse()
	go func() {
		for true {
			numOfBuns.WithLabelValues("guan_yu","25").Add(2)
			numOfBuns.WithLabelValues("zhang_fei","22").Add(3)
			time.Sleep(time.Second)
		}
	}()
	http.Handle("/metrics", promhttp.Handler())
	log.Fatal(http.ListenAndServe(*addr, nil))
}
  • 显示结果
# HELP xi_shu_jing_zhou_team_eaten_num Number of steamed buns eaten by Guan Yu
# TYPE xi_shu_jing_zhou_team_eaten_num gauge
xi_shu_jing_zhou_team_eaten_num{age="22",name="zhang_fei"} 33
xi_shu_jing_zhou_team_eaten_num{age="25",name="guan_yu"} 22

在这里插入图片描述

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

玄德公笔记

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值