2016-02-11 16:16:52 +02:00
|
|
|
// Hook go-metrics into expvar
|
|
|
|
// on any /debug/metrics request, load all vars from the registry into expvar, and execute regular expvar handler
|
|
|
|
package exp
|
|
|
|
|
|
|
|
import (
|
|
|
|
"fmt"
|
|
|
|
"net/http"
|
2016-10-28 20:05:01 +03:00
|
|
|
|
2021-07-29 17:27:46 +07:00
|
|
|
metrics2 "github.com/VictoriaMetrics/metrics"
|
2021-07-29 17:23:23 +07:00
|
|
|
"github.com/ledgerwatch/log/v3"
|
2016-02-11 16:16:52 +02:00
|
|
|
)
|
|
|
|
|
2020-07-03 12:12:22 -05:00
|
|
|
// Setup starts a dedicated metrics server at the given address.
|
|
|
|
// This function enables metrics reporting separate from pprof.
|
|
|
|
func Setup(address string) {
|
2021-07-29 17:27:46 +07:00
|
|
|
http.HandleFunc("/debug/metrics/prometheus", func(w http.ResponseWriter, r *http.Request) {
|
2022-03-10 01:40:53 +07:00
|
|
|
w.Header().Set("Access-Control-Allow-Origin", "*")
|
2021-07-29 17:27:46 +07:00
|
|
|
metrics2.WritePrometheus(w, true)
|
|
|
|
})
|
|
|
|
//m.Handle("/debug/metrics", ExpHandler(metrics.DefaultRegistry))
|
|
|
|
//m.Handle("/debug/metrics/prometheus2", promhttp.HandlerFor(prometheus2.DefaultGatherer, promhttp.HandlerOpts{
|
|
|
|
// EnableOpenMetrics: true,
|
|
|
|
//}))
|
|
|
|
log.Info("Starting metrics server", "addr", fmt.Sprintf("http://%s/debug/metrics/prometheus", address))
|
2020-07-03 12:12:22 -05:00
|
|
|
go func() {
|
2022-08-25 04:08:56 +02:00
|
|
|
if err := http.ListenAndServe(address, nil); err != nil { // nolint:gosec
|
2020-07-03 12:12:22 -05:00
|
|
|
log.Error("Failure in running metrics server", "err", err)
|
|
|
|
}
|
|
|
|
}()
|
|
|
|
}
|