* go-metrics: fork library and introduce ResettingTimer and InfluxDB reporter. * vendor: change nonsense/go-metrics to ethersphere/go-metrics * go-metrics: add tests. move ResettingTimer logic from reporter to type. * all, metrics: pull in metrics package in go-ethereum * metrics/test: make sure metrics are enabled for tests * metrics: apply gosimple rules * metrics/exp, internal/debug: init expvar endpoint when starting pprof server * internal/debug: tiny comment formatting fix
		
			
				
	
	
		
			128 lines
		
	
	
		
			3.3 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			128 lines
		
	
	
		
			3.3 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
| package metrics
 | |
| 
 | |
| import "sync"
 | |
| 
 | |
| // GaugeFloat64s hold a float64 value that can be set arbitrarily.
 | |
| type GaugeFloat64 interface {
 | |
| 	Snapshot() GaugeFloat64
 | |
| 	Update(float64)
 | |
| 	Value() float64
 | |
| }
 | |
| 
 | |
| // GetOrRegisterGaugeFloat64 returns an existing GaugeFloat64 or constructs and registers a
 | |
| // new StandardGaugeFloat64.
 | |
| func GetOrRegisterGaugeFloat64(name string, r Registry) GaugeFloat64 {
 | |
| 	if nil == r {
 | |
| 		r = DefaultRegistry
 | |
| 	}
 | |
| 	return r.GetOrRegister(name, NewGaugeFloat64()).(GaugeFloat64)
 | |
| }
 | |
| 
 | |
| // NewGaugeFloat64 constructs a new StandardGaugeFloat64.
 | |
| func NewGaugeFloat64() GaugeFloat64 {
 | |
| 	if !Enabled {
 | |
| 		return NilGaugeFloat64{}
 | |
| 	}
 | |
| 	return &StandardGaugeFloat64{
 | |
| 		value: 0.0,
 | |
| 	}
 | |
| }
 | |
| 
 | |
| // NewRegisteredGaugeFloat64 constructs and registers a new StandardGaugeFloat64.
 | |
| func NewRegisteredGaugeFloat64(name string, r Registry) GaugeFloat64 {
 | |
| 	c := NewGaugeFloat64()
 | |
| 	if nil == r {
 | |
| 		r = DefaultRegistry
 | |
| 	}
 | |
| 	r.Register(name, c)
 | |
| 	return c
 | |
| }
 | |
| 
 | |
| // NewFunctionalGauge constructs a new FunctionalGauge.
 | |
| func NewFunctionalGaugeFloat64(f func() float64) GaugeFloat64 {
 | |
| 	if !Enabled {
 | |
| 		return NilGaugeFloat64{}
 | |
| 	}
 | |
| 	return &FunctionalGaugeFloat64{value: f}
 | |
| }
 | |
| 
 | |
| // NewRegisteredFunctionalGauge constructs and registers a new StandardGauge.
 | |
| func NewRegisteredFunctionalGaugeFloat64(name string, r Registry, f func() float64) GaugeFloat64 {
 | |
| 	c := NewFunctionalGaugeFloat64(f)
 | |
| 	if nil == r {
 | |
| 		r = DefaultRegistry
 | |
| 	}
 | |
| 	r.Register(name, c)
 | |
| 	return c
 | |
| }
 | |
| 
 | |
| // GaugeFloat64Snapshot is a read-only copy of another GaugeFloat64.
 | |
| type GaugeFloat64Snapshot float64
 | |
| 
 | |
| // Snapshot returns the snapshot.
 | |
| func (g GaugeFloat64Snapshot) Snapshot() GaugeFloat64 { return g }
 | |
| 
 | |
| // Update panics.
 | |
| func (GaugeFloat64Snapshot) Update(float64) {
 | |
| 	panic("Update called on a GaugeFloat64Snapshot")
 | |
| }
 | |
| 
 | |
| // Value returns the value at the time the snapshot was taken.
 | |
| func (g GaugeFloat64Snapshot) Value() float64 { return float64(g) }
 | |
| 
 | |
| // NilGauge is a no-op Gauge.
 | |
| type NilGaugeFloat64 struct{}
 | |
| 
 | |
| // Snapshot is a no-op.
 | |
| func (NilGaugeFloat64) Snapshot() GaugeFloat64 { return NilGaugeFloat64{} }
 | |
| 
 | |
| // Update is a no-op.
 | |
| func (NilGaugeFloat64) Update(v float64) {}
 | |
| 
 | |
| // Value is a no-op.
 | |
| func (NilGaugeFloat64) Value() float64 { return 0.0 }
 | |
| 
 | |
| // StandardGaugeFloat64 is the standard implementation of a GaugeFloat64 and uses
 | |
| // sync.Mutex to manage a single float64 value.
 | |
| type StandardGaugeFloat64 struct {
 | |
| 	mutex sync.Mutex
 | |
| 	value float64
 | |
| }
 | |
| 
 | |
| // Snapshot returns a read-only copy of the gauge.
 | |
| func (g *StandardGaugeFloat64) Snapshot() GaugeFloat64 {
 | |
| 	return GaugeFloat64Snapshot(g.Value())
 | |
| }
 | |
| 
 | |
| // Update updates the gauge's value.
 | |
| func (g *StandardGaugeFloat64) Update(v float64) {
 | |
| 	g.mutex.Lock()
 | |
| 	defer g.mutex.Unlock()
 | |
| 	g.value = v
 | |
| }
 | |
| 
 | |
| // Value returns the gauge's current value.
 | |
| func (g *StandardGaugeFloat64) Value() float64 {
 | |
| 	g.mutex.Lock()
 | |
| 	defer g.mutex.Unlock()
 | |
| 	return g.value
 | |
| }
 | |
| 
 | |
| // FunctionalGaugeFloat64 returns value from given function
 | |
| type FunctionalGaugeFloat64 struct {
 | |
| 	value func() float64
 | |
| }
 | |
| 
 | |
| // Value returns the gauge's current value.
 | |
| func (g FunctionalGaugeFloat64) Value() float64 {
 | |
| 	return g.value()
 | |
| }
 | |
| 
 | |
| // Snapshot returns the snapshot.
 | |
| func (g FunctionalGaugeFloat64) Snapshot() GaugeFloat64 { return GaugeFloat64Snapshot(g.Value()) }
 | |
| 
 | |
| // Update panics.
 | |
| func (FunctionalGaugeFloat64) Update(float64) {
 | |
| 	panic("Update called on a FunctionalGaugeFloat64")
 | |
| }
 |