mirror of
https://gitlab.com/pulsechaincom/erigon-pulse.git
synced 2025-01-19 00:54:12 +00:00
8ea0096d56
This is a non functional change which consolidates the various packages under metrics into the top level package now that the dead code is removed. It is a precursor to the removal of Victoria metrics after which all erigon metrics code will be contained in this single package.
55 lines
1.1 KiB
Go
55 lines
1.1 KiB
Go
package metrics
|
|
|
|
import (
|
|
"fmt"
|
|
"strings"
|
|
"time"
|
|
|
|
"github.com/VictoriaMetrics/metrics"
|
|
)
|
|
|
|
type HistTimer struct {
|
|
*metrics.Histogram
|
|
|
|
start time.Time
|
|
|
|
name string
|
|
}
|
|
|
|
func NewHistTimer(name string) *HistTimer {
|
|
rawName := strings.Split(name, "{")
|
|
return &HistTimer{
|
|
Histogram: metrics.GetOrCreateCompatibleHistogram(name),
|
|
start: time.Now(),
|
|
name: rawName[0],
|
|
}
|
|
}
|
|
|
|
func (h *HistTimer) PutSince() {
|
|
h.Histogram.UpdateDuration(h.start)
|
|
}
|
|
|
|
func (h *HistTimer) Tag(pairs ...string) *HistTimer {
|
|
if len(pairs)%2 != 0 {
|
|
pairs = append(pairs, "UNEQUAL_KEY_VALUE_TAGS")
|
|
}
|
|
toJoin := []string{}
|
|
for i := 0; i < len(pairs); i = i + 2 {
|
|
toJoin = append(toJoin, fmt.Sprintf(`%s="%s"`, pairs[i], pairs[i+1]))
|
|
}
|
|
tags := ""
|
|
if len(toJoin) > 0 {
|
|
tags = "{" + strings.Join(toJoin, ",") + "}"
|
|
}
|
|
return &HistTimer{
|
|
Histogram: metrics.GetOrCreateCompatibleHistogram(h.name + tags),
|
|
start: time.Now(),
|
|
name: h.name,
|
|
}
|
|
}
|
|
|
|
func (h *HistTimer) Child(suffix string) *HistTimer {
|
|
suffix = strings.TrimPrefix(suffix, "_")
|
|
return NewHistTimer(h.name + "_" + suffix)
|
|
}
|