2016-11-09 15:30:07 -05:00
// Copyright 2016 Circonus, Inc. All rights reserved.
// Use of this source code is governed by a BSD-style
// license that can be found in the LICENSE file.
2016-07-19 16:40:41 -07:00
package circonusgometrics
import (
2019-06-19 14:50:48 +02:00
"fmt"
2016-07-19 16:40:41 -07:00
"sync"
"github.com/circonus-labs/circonusllhist"
)
// Histogram measures the distribution of a stream of values.
type Histogram struct {
name string
hist * circonusllhist . Histogram
rw sync . RWMutex
}
// Timing adds a value to a histogram
func ( m * CirconusMetrics ) Timing ( metric string , val float64 ) {
m . SetHistogramValue ( metric , val )
}
// RecordValue adds a value to a histogram
func ( m * CirconusMetrics ) RecordValue ( metric string , val float64 ) {
m . SetHistogramValue ( metric , val )
}
2019-06-19 14:50:48 +02:00
// RecordCountForValue adds count n for value to a histogram
func ( m * CirconusMetrics ) RecordCountForValue ( metric string , val float64 , n int64 ) {
hist := m . NewHistogram ( metric )
m . hm . Lock ( )
hist . rw . Lock ( )
hist . hist . RecordValues ( val , n )
hist . rw . Unlock ( )
m . hm . Unlock ( )
}
2016-07-19 16:40:41 -07:00
// SetHistogramValue adds a value to a histogram
func ( m * CirconusMetrics ) SetHistogramValue ( metric string , val float64 ) {
2016-11-09 15:30:07 -05:00
hist := m . NewHistogram ( metric )
2016-07-19 16:40:41 -07:00
2016-11-09 15:30:07 -05:00
m . hm . Lock ( )
hist . rw . Lock ( )
hist . hist . RecordValue ( val )
hist . rw . Unlock ( )
m . hm . Unlock ( )
2016-07-19 16:40:41 -07:00
}
2019-06-19 14:50:48 +02:00
// GetHistogramTest returns the current value for a gauge. (note: it is a function specifically for "testing", disable automatic submission during testing.)
func ( m * CirconusMetrics ) GetHistogramTest ( metric string ) ( [ ] string , error ) {
m . hm . Lock ( )
defer m . hm . Unlock ( )
if hist , ok := m . histograms [ metric ] ; ok {
return hist . hist . DecStrings ( ) , nil
}
return [ ] string { "" } , fmt . Errorf ( "Histogram metric '%s' not found" , metric )
}
2016-07-19 16:40:41 -07:00
// RemoveHistogram removes a histogram
func ( m * CirconusMetrics ) RemoveHistogram ( metric string ) {
m . hm . Lock ( )
delete ( m . histograms , metric )
2016-11-09 15:30:07 -05:00
m . hm . Unlock ( )
2016-07-19 16:40:41 -07:00
}
// NewHistogram returns a histogram instance.
func ( m * CirconusMetrics ) NewHistogram ( metric string ) * Histogram {
m . hm . Lock ( )
defer m . hm . Unlock ( )
if hist , ok := m . histograms [ metric ] ; ok {
return hist
}
hist := & Histogram {
name : metric ,
hist : circonusllhist . New ( ) ,
}
m . histograms [ metric ] = hist
return hist
}
// Name returns the name from a histogram instance
func ( h * Histogram ) Name ( ) string {
return h . name
}
// RecordValue records the given value to a histogram instance
func ( h * Histogram ) RecordValue ( v float64 ) {
h . rw . Lock ( )
h . hist . RecordValue ( v )
2016-11-09 15:30:07 -05:00
h . rw . Unlock ( )
2016-07-19 16:40:41 -07:00
}