gin-gonic/gin metrics exporter for Prometheus.
gin-metrics
defines some metrics for gin http-server. There have easy way to use it.
Below is the detailed description for every metric.
Metric | Type | Description |
---|---|---|
gin_request_total | Counter | all the server received request num. |
gin_request_uv | Counter | all the server received ip num. |
gin_uri_request_total | Counter | all the server received request num with every uri. |
gin_request_body_total | Counter | the server received request body size, unit byte. |
gin_response_body_total | Counter | the server send response body size, unit byte. |
gin_request_duration | Histogram | the time server took to handle the request. |
gin_slow_request_total | Counter | the server handled slow requests counter, t=%d. |
Set the grafana
directory for details.
$ go get github.com/penglongli/gin-metrics
Your can see some metrics across 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()
}
gin-metric
provides ways to custom your own metric.
With Gauge
type metric, you can use three functions to change it's value.
And you should define a Gauge
Metric first,
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
will setting metric value directly。
_ = ginmetrics.GetMonitor().GetMetric("example_gauge_metric").SetGaugeValue([]string{"label_value1"}, 0.1)
Inc
Inc
will increase 1 to metric value
_ = ginmetrics.GetMonitor().GetMetric("example_gauge_metric").Inc([]string{"label_value1"})
Add
Add
will add float64 num to metric value
_ = ginmetrics.GetMonitor().GetMetric("example_gauge_metric").Add([]string{"label_value1"}, 0.2)
With Counter
type metric, you can use Inc
and Add
function, don't use SetGaugeValue
.
For Histogram
and Summary
type metric, should use Observe
function.
For some users, they don't want to merge the port of the metric with the port of the application.
So we provide a way to separate the metric port. Here is the example.
func main() {
appRouter := gin.Default()
metricRouter := gin.Default()
m := ginmetrics.GetMonitor()
// use metric middleware without expose metric path
m.UseWithoutExposingEndpoint(appRouter)
// set metric path expose to metric router
m.Expose(metricRouter)
appRouter.GET("/product/:id", func(ctx *gin.Context) {
ctx.JSON(200, map[string]string{
"productId": ctx.Param("id"),
})
})
go func() {
_ = metricRouter.Run(":8081")
}()
_ = appRouter.Run(":8080")
}
If someone has a problem or suggestions, you can submit new issues or new pull requests.