Prometheus
El middleware Echo Prometheus genera metrics Prometheus para requests HTTP.
Agrega el módulo requerido:
go get github.com/labstack/echo-prometheusAgrega el middleware Prometheus y una ruta para servir las metrics recopiladas:
e := echo.New()e.Use(echoprometheus.NewMiddleware("myapp")) // adds middleware to gather metricse.GET("/metrics", echoprometheus.NewHandler()) // adds route to serve gathered metricsEjemplos
Sección titulada «Ejemplos»Servir metrics desde el mismo servidor que las recopila:
package main
import ( "net/http"
echoprometheus "github.com/labstack/echo-prometheus" "github.com/labstack/echo/v5")
func main() { e := echo.New()
e.Use(echoprometheus.NewMiddleware("myapp")) // adds middleware to gather metrics e.GET("/metrics", echoprometheus.NewHandler()) // adds route to serve gathered metrics
e.GET("/hello", func(c *echo.Context) error { return c.String(http.StatusOK, "hello") })
if err := e.Start(":8080"); err != nil { e.Logger.Error("failed to start server", "error", err) }}Servir metrics en un puerto separado:
func main() { e := echo.New() // this Echo instance will serve routes on port 8080 e.Use(echoprometheus.NewMiddleware("myapp")) // adds middleware to gather metrics
go func() { metrics := echo.New() // this Echo will run on separate port 8081 metrics.GET("/metrics", echoprometheus.NewHandler()) // adds route to serve gathered metrics if err := metrics.Start(":8081"); err != nil { e.Logger.Error("failed to start metrics server", "error", err) } }()
e.GET("/hello", func(c *echo.Context) error { return c.String(http.StatusOK, "hello") })
if err := e.Start(":8080"); err != nil { e.Logger.Error("failed to start server", "error", err) }}Salida de ejemplo (para el primer ejemplo):
curl http://localhost:8080/metrics
# HELP echo_request_duration_seconds The HTTP request latencies in seconds.# TYPE echo_request_duration_seconds summaryecho_request_duration_seconds_sum 0.41086482echo_request_duration_seconds_count 1# HELP echo_request_size_bytes The HTTP request sizes in bytes.# TYPE echo_request_size_bytes summaryecho_request_size_bytes_sum 56echo_request_size_bytes_count 1# HELP echo_requests_total How many HTTP requests processed, partitioned by status code and HTTP method.# TYPE echo_requests_total counterecho_requests_total{code="200",host="localhost:8080",method="GET",url="/"} 1# HELP echo_response_size_bytes The HTTP response sizes in bytes.# TYPE echo_response_size_bytes summaryecho_response_size_bytes_sum 61echo_response_size_bytes_count 1...Configuración personalizada
Sección titulada «Configuración personalizada»Servir metrics Prometheus personalizadas
Sección titulada «Servir metrics Prometheus personalizadas»Usa metrics personalizadas con el registry por defecto de Prometheus:
package main
import ( "log"
echoprometheus "github.com/labstack/echo-prometheus" "github.com/labstack/echo/v5" "github.com/prometheus/client_golang/prometheus")
func main() { e := echo.New() // this Echo instance will serve routes on port 8080
customCounter := prometheus.NewCounter( // create a new counter metric prometheus.CounterOpts{ Name: "custom_requests_total", Help: "How many HTTP requests processed, partitioned by status code and HTTP method.", }, ) if err := prometheus.Register(customCounter); err != nil { // register the counter with the default registry log.Fatal(err) }
e.Use(echoprometheus.NewMiddlewareWithConfig(echoprometheus.MiddlewareConfig{ AfterNext: func(c *echo.Context, err error) { customCounter.Inc() // increment the counter after every request }, })) e.GET("/metrics", echoprometheus.NewHandler()) // register a route to serve gathered metrics
if err := e.Start(":8080"); err != nil { e.Logger.Error("failed to start server", "error", err) }}O crea tu propio registry y registra metrics personalizadas con él:
package main
import ( "log"
echoprometheus "github.com/labstack/echo-prometheus" "github.com/labstack/echo/v5" "github.com/prometheus/client_golang/prometheus")
func main() { e := echo.New() // this Echo instance will serve routes on port 8080
customRegistry := prometheus.NewRegistry() // create a custom registry for your custom metrics customCounter := prometheus.NewCounter( // create a new counter metric prometheus.CounterOpts{ Name: "custom_requests_total", Help: "How many HTTP requests processed, partitioned by status code and HTTP method.", }, ) if err := customRegistry.Register(customCounter); err != nil { // register the counter with the custom registry log.Fatal(err) }
e.Use(echoprometheus.NewMiddlewareWithConfig(echoprometheus.MiddlewareConfig{ AfterNext: func(c *echo.Context, err error) { customCounter.Inc() // increment the counter after every request }, Registerer: customRegistry, // use the custom registry instead of the default Prometheus registry })) e.GET("/metrics", echoprometheus.NewHandlerWithConfig(echoprometheus.HandlerConfig{Gatherer: customRegistry})) // serve metrics from the custom registry
if err := e.Start(":8080"); err != nil { e.Logger.Error("failed to start server", "error", err) }}Omitir URLs
Sección titulada «Omitir URLs»Se puede pasar un skipper para evitar generar metrics en ciertas URLs:
package main
import ( "net/http" "strings"
echoprometheus "github.com/labstack/echo-prometheus" "github.com/labstack/echo/v5")
func main() { e := echo.New() // this Echo instance will serve routes on port 8080
mwConfig := echoprometheus.MiddlewareConfig{ Skipper: func(c *echo.Context) bool { return strings.HasPrefix(c.Path(), "/testurl") }, // does not gather metrics on routes starting with `/testurl` } e.Use(echoprometheus.NewMiddlewareWithConfig(mwConfig)) // adds middleware to gather metrics
e.GET("/metrics", echoprometheus.NewHandler()) // adds route to serve gathered metrics
e.GET("/", func(c *echo.Context) error { return c.String(http.StatusOK, "Hello, World!") })
if err := e.Start(":8080"); err != nil { e.Logger.Error("failed to start server", "error", err) }}Escenarios complejos
Sección titulada «Escenarios complejos»Modificar las definiciones de metrics por defecto de echoprometheus:
package main
import ( "net/http"
echoprometheus "github.com/labstack/echo-prometheus" "github.com/labstack/echo/v5" "github.com/prometheus/client_golang/prometheus")
func main() { e := echo.New() // this Echo instance will serve routes on port 8080
e.Use(echoprometheus.NewMiddlewareWithConfig(echoprometheus.MiddlewareConfig{ // Labels of default metrics can be modified or added with the `LabelFuncs` function. LabelFuncs: map[string]echoprometheus.LabelValueFunc{ "scheme": func(c *echo.Context, err error) string { // additional custom label return c.Scheme() }, "host": func(c *echo.Context, err error) string { // overrides the default 'host' label value return "y_" + c.Request().Host }, }, // The `echoprometheus` middleware registers the following metrics by default: // - Histogram: request_duration_seconds // - Histogram: response_size_bytes // - Histogram: request_size_bytes // - Counter: requests_total // which can be modified with the `HistogramOptsFunc` and `CounterOptsFunc` functions. HistogramOptsFunc: func(opts prometheus.HistogramOpts) prometheus.HistogramOpts { if opts.Name == "request_duration_seconds" { opts.Buckets = []float64{1000.0, 10_000.0, 100_000.0, 1_000_000.0} // 1KB, 10KB, 100KB, 1MB } return opts }, CounterOptsFunc: func(opts prometheus.CounterOpts) prometheus.CounterOpts { if opts.Name == "requests_total" { opts.ConstLabels = prometheus.Labels{"my_const": "123"} } return opts }, })) // adds middleware to gather metrics
e.GET("/metrics", echoprometheus.NewHandler()) // adds route to serve gathered metrics
e.GET("/hello", func(c *echo.Context) error { return c.String(http.StatusOK, "hello") })
if err := e.Start(":8080"); err != nil { e.Logger.Error("failed to start server", "error", err) }}