mirror of
https://gitlab.com/pulsechaincom/erigon-pulse.git
synced 2025-01-05 02:24:29 +00:00
a4cfbe0d56
This is an update of: https://github.com/ledgerwatch/erigon/pull/7846 which uses a local fork of victoria metrics to include the changes that https://github.com/anshalshukla added to the original for we where using. It also includes code to address the duplicate metrics issue identified here: https://github.com/ledgerwatch/erigon/issues/8053 It has one more associated fix which is to correctly add a metadata label to counters, these where previously labelled as gauges. e.g. ``` # TYPE p2p_peers counter p2p_peers 0 ``` rather than ``` # TYPE p2p_peers gauge p2p_peers 0 ``` --------- Co-authored-by: Anshal Shukla <53994948+anshalshukla@users.noreply.github.com> Co-authored-by: Anshal Shukla <shukla.anshal85@gmail.com>
35 lines
860 B
Go
35 lines
860 B
Go
package diagnostics
|
|
|
|
import (
|
|
"fmt"
|
|
"io"
|
|
"net/http"
|
|
"strconv"
|
|
|
|
"github.com/ledgerwatch/erigon/dataflow"
|
|
)
|
|
|
|
func SetupBlockBodyDownload(metricsMux *http.ServeMux) {
|
|
metricsMux.HandleFunc("/debug/metrics/block_body_download", func(w http.ResponseWriter, r *http.Request) {
|
|
w.Header().Set("Access-Control-Allow-Origin", "*")
|
|
writeBlockBodyDownload(w, r)
|
|
})
|
|
}
|
|
|
|
func writeBlockBodyDownload(w io.Writer, r *http.Request) {
|
|
if err := r.ParseForm(); err != nil {
|
|
fmt.Fprintf(w, "ERROR: parsing arguments: %v\n", err)
|
|
return
|
|
}
|
|
sinceTickStr := r.Form.Get("sincetick")
|
|
var tick int64
|
|
if sinceTickStr != "" {
|
|
var err error
|
|
if tick, err = strconv.ParseInt(sinceTickStr, 10, 64); err != nil {
|
|
fmt.Fprintf(w, "ERROR: parsing sincemilli: %v\n", err)
|
|
}
|
|
}
|
|
fmt.Fprintf(w, "SUCCESS\n")
|
|
dataflow.BlockBodyDownloadStates.ChangesSince(int(tick), w)
|
|
}
|