Skip to content

Latest commit

 

History

History
126 lines (83 loc) · 3.37 KB

README_zh.md

File metadata and controls

126 lines (83 loc) · 3.37 KB

gin-metrics

gin-gonic/gin metrics exporter for Prometheus.

Introduction

gin-metrics 为 gin HTTP 服务定义了一些监控指标,开箱即用。下边是默认监控指标的详细描述:

Metric Type Description
gin_request_total Counter 服务接收到的请求总数
gin_request_uv Counter 服务接收到的 IP 总数
gin_uri_request_total Counter 每个 URI 接收到的服务请求数
gin_request_body_total Counter 服务接收到的请求量,单位: 字节
gin_response_body_total Counter 服务返回的请求量,单位: 字节
gin_request_duration Histogram 服务处理请求使用的时间
gin_slow_request_total Counter 服务接收到的慢请求计数

Installation

$ go get github.com/penglongli/gin-metrics

Usage

使用如下代码运行,访问:http://localhost:8080/metrics 即可看到暴露出来的监控指标

package main

import (
	"github.com/gin-gonic/gin"

	"github.com/penglongli/gin-metrics/ginmetrics"
)

func main() {
	r := gin.Default()

	// get global Monitor object
	m := ginmetrics.GetMonitor()

	// +optional set metric path, default /debug/metrics
	m.SetMetricPath("/metrics")
	// +optional set slow time, default 5s
	m.SetSlowTime(10)
	// +optional set request duration, default {0.1, 0.3, 1.2, 5, 10}
	// used to p95, p99
	m.SetDuration([]float64{0.1, 0.3, 1.2, 5, 10})

	// set middleware for gin
	m.Use(r)

	r.GET("/product/:id", func(ctx *gin.Context) {
		ctx.JSON(200, map[string]string{
			"productId": ctx.Param("id"),
		})
	})

	_ = r.Run()
}

Custom Metric

gin-metric 提供了自定义监控指标的使用方式

Gauge

使用 Gauge 类型监控指标,可以通过 3 种方法来修改监控值:SetGaugeValueIncAdd

首先,需要定义一个 Gauge 类型的监控指标:

gaugeMetric := &ginmetrics.Metric{
    Type:        ginmetrics.Gauge,
    Name:        "example_gauge_metric",
    Description: "an example of gauge type metric",
    Labels:      []string{"label1"},
}

// Add metric to global monitor object
_ = ginmetrics.GetMonitor().AddMetric(gaugeMetric)

SetGaugeValue

SetGaugeValue 方法会直接设置监控指标的值

_ = ginmetrics.GetMonitor().GetMetric("example_gauge_metric").SetGaugeValue([]string{"label_value1"}, 0.1)

Inc

Inc 方法会在监控指标值的基础上增加 1

_ = ginmetrics.GetMonitor().GetMetric("example_gauge_metric").Inc([]string{"label_value1"})

Add

Add 方法会为监控指标增加传入的值

_ = ginmetrics.GetMonitor().GetMetric("example_gauge_metric").Add([]string{"label_value1"}, 0.2)

Counter

Counter 类型的监控指标,可以使用 IncAdd 方法,但是不能使用 SetGaugeValue 方法

Histogram and Summary

对于 HistogramSummary 类型的监控指标,需要用 Observe 方法来设置监控值。

Contributing

如果有遇见什么问题,或者需要修改,可以 新建 ISSUE 或者 新建 PullRequest.