increase.go 1.2 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667
  1. package aggregator
  2. import (
  3. "sync"
  4. "time"
  5. )
  6. type increaseAggregator struct {
  7. lock sync.Mutex
  8. name string
  9. labelValues []string
  10. initialized bool
  11. initialTime time.Time
  12. currentTime time.Time
  13. initial float64
  14. current float64
  15. }
  16. func Increase(name string, labelValues []string) MetricAggregator {
  17. return &increaseAggregator{
  18. name: name,
  19. labelValues: labelValues,
  20. }
  21. }
  22. func (a *increaseAggregator) Name() string {
  23. return a.name
  24. }
  25. func (a *increaseAggregator) AdditionInfo() map[string]string {
  26. return nil
  27. }
  28. func (a *increaseAggregator) LabelValues() []string {
  29. return a.labelValues
  30. }
  31. func (a *increaseAggregator) Update(value float64, timestamp time.Time, additionalInfo map[string]string) {
  32. a.lock.Lock()
  33. defer a.lock.Unlock()
  34. if !a.initialized {
  35. a.initialTime = timestamp
  36. a.currentTime = timestamp
  37. a.initialized = true
  38. }
  39. if a.initialTime == timestamp {
  40. a.initial += value
  41. }
  42. if a.currentTime.Before(timestamp) {
  43. a.currentTime = timestamp
  44. a.current = 0
  45. }
  46. a.current += value
  47. }
  48. func (a *increaseAggregator) Value() []MetricValue {
  49. a.lock.Lock()
  50. defer a.lock.Unlock()
  51. if !a.initialized {
  52. return []MetricValue{}
  53. }
  54. return []MetricValue{
  55. {Value: a.current - a.initial},
  56. }
  57. }