mirror of
https://gitlab.com/pulsechaincom/erigon-pulse.git
synced 2025-01-08 03:51:20 +00:00
0bdca6c457
Fixes for label discrepancies in collector for summaries etc which have a template which includes a quantile. Initial native Prometheus client implementation of metrics - which is currently turned off except for local testing and interface exports.
88 lines
2.5 KiB
Go
88 lines
2.5 KiB
Go
package heimdall
|
|
|
|
import (
|
|
"context"
|
|
"time"
|
|
|
|
"github.com/ledgerwatch/erigon/metrics"
|
|
)
|
|
|
|
type (
|
|
requestTypeKey struct{}
|
|
requestType string
|
|
|
|
meter struct {
|
|
request map[bool]metrics.Counter // map[isSuccessful]metrics.Meter
|
|
timer metrics.Summary
|
|
}
|
|
)
|
|
|
|
const (
|
|
stateSyncRequest requestType = "state-sync"
|
|
spanRequest requestType = "span"
|
|
checkpointRequest requestType = "checkpoint"
|
|
checkpointCountRequest requestType = "checkpoint-count"
|
|
milestoneRequest requestType = "milestone"
|
|
milestoneCountRequest requestType = "milestone-count"
|
|
milestoneNoAckRequest requestType = "milestone-no-ack"
|
|
milestoneLastNoAckRequest requestType = "milestone-last-no-ack"
|
|
milestoneIDRequest requestType = "milestone-id"
|
|
)
|
|
|
|
func withRequestType(ctx context.Context, reqType requestType) context.Context {
|
|
return context.WithValue(ctx, requestTypeKey{}, reqType)
|
|
}
|
|
|
|
func getRequestType(ctx context.Context) (requestType, bool) {
|
|
reqType, ok := ctx.Value(requestTypeKey{}).(requestType)
|
|
return reqType, ok
|
|
}
|
|
|
|
var (
|
|
requestMeters = map[requestType]meter{
|
|
stateSyncRequest: {
|
|
request: map[bool]metrics.Counter{
|
|
true: metrics.GetOrCreateCounter("client_requests_statesync_valid"),
|
|
false: metrics.GetOrCreateCounter("client_requests_statesync_invalid"),
|
|
},
|
|
timer: metrics.GetOrCreateSummary("client_requests_statesync_duration"),
|
|
},
|
|
spanRequest: {
|
|
request: map[bool]metrics.Counter{
|
|
true: metrics.GetOrCreateCounter("client_requests_span_valid"),
|
|
false: metrics.GetOrCreateCounter("client_requests_span_invalid"),
|
|
},
|
|
timer: metrics.GetOrCreateSummary("client_requests_span_duration"),
|
|
},
|
|
checkpointRequest: {
|
|
request: map[bool]metrics.Counter{
|
|
true: metrics.GetOrCreateCounter("client_requests_checkpoint_valid"),
|
|
false: metrics.GetOrCreateCounter("client_requests_checkpoint_invalid"),
|
|
},
|
|
timer: metrics.GetOrCreateSummary("client_requests_checkpoint_duration"),
|
|
},
|
|
checkpointCountRequest: {
|
|
request: map[bool]metrics.Counter{
|
|
true: metrics.GetOrCreateCounter("client_requests_checkpointcount_valid"),
|
|
false: metrics.GetOrCreateCounter("client_requests_checkpointcount_invalid"),
|
|
},
|
|
timer: metrics.GetOrCreateSummary("client_requests_checkpointcount_duration"),
|
|
},
|
|
}
|
|
)
|
|
|
|
func sendMetrics(ctx context.Context, start time.Time, isSuccessful bool) {
|
|
reqType, ok := getRequestType(ctx)
|
|
if !ok {
|
|
return
|
|
}
|
|
|
|
meters, ok := requestMeters[reqType]
|
|
if !ok {
|
|
return
|
|
}
|
|
|
|
meters.request[isSuccessful].Set(1)
|
|
meters.timer.UpdateDuration(start)
|
|
}
|