2016-02-11 14:16:52 +00:00
|
|
|
// Hook go-metrics into expvar
|
|
|
|
// on any /debug/metrics request, load all vars from the registry into expvar, and execute regular expvar handler
|
2023-09-03 01:09:27 +00:00
|
|
|
package metrics
|
2016-02-11 14:16:52 +00:00
|
|
|
|
|
|
|
import (
|
|
|
|
"fmt"
|
|
|
|
"net/http"
|
2016-10-28 17:05:01 +00:00
|
|
|
|
2021-07-29 10:23:23 +00:00
|
|
|
"github.com/ledgerwatch/log/v3"
|
2016-02-11 14:16:52 +00:00
|
|
|
)
|
|
|
|
|
2023-09-13 10:49:49 +00:00
|
|
|
var EnabledExpensive = false
|
|
|
|
|
2020-07-03 17:12:22 +00:00
|
|
|
// Setup starts a dedicated metrics server at the given address.
|
|
|
|
// This function enables metrics reporting separate from pprof.
|
2023-08-31 08:04:27 +00:00
|
|
|
func Setup(address string, logger log.Logger) *http.ServeMux {
|
|
|
|
prometheusMux := http.NewServeMux()
|
|
|
|
|
2023-09-03 01:09:27 +00:00
|
|
|
prometheusMux.Handle("/debug/metrics/prometheus", Handler(DefaultRegistry))
|
2023-08-31 08:04:27 +00:00
|
|
|
|
|
|
|
promServer := &http.Server{
|
|
|
|
Addr: address,
|
|
|
|
Handler: prometheusMux,
|
|
|
|
}
|
|
|
|
|
2020-07-03 17:12:22 +00:00
|
|
|
go func() {
|
2023-08-31 08:04:27 +00:00
|
|
|
if err := promServer.ListenAndServe(); err != nil {
|
|
|
|
log.Error("Failure in running Prometheus server", "err", err)
|
2020-07-03 17:12:22 +00:00
|
|
|
}
|
|
|
|
}()
|
2023-08-31 08:04:27 +00:00
|
|
|
|
|
|
|
log.Info("Enabling metrics export to prometheus", "path", fmt.Sprintf("http://%s/debug/metrics/prometheus", address))
|
|
|
|
|
|
|
|
return prometheusMux
|
2020-07-03 17:12:22 +00:00
|
|
|
}
|