stathat.go 2.6 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364
  1. package metrics
  2. import (
  3. "log"
  4. "time"
  5. "github.com/stathat/go"
  6. )
  7. func Stathat(r Registry, d time.Duration, userkey string) {
  8. for {
  9. if err := sh(r, userkey); nil != err {
  10. log.Println(err)
  11. }
  12. time.Sleep(d)
  13. }
  14. }
  15. func sh(r Registry, userkey string) error {
  16. r.Each(func(name string, i interface{}) {
  17. switch m := i.(type) {
  18. case Counter:
  19. stathat.PostEZCount(name, userkey, int(m.Count()))
  20. case Gauge:
  21. stathat.PostEZValue(name, userkey, float64(m.Value()))
  22. case Histogram:
  23. ps := m.Percentiles([]float64{0.5, 0.75, 0.95, 0.99, 0.999})
  24. stathat.PostEZCount(name+".count", userkey, int(m.Count()))
  25. stathat.PostEZValue(name+".min", userkey, float64(m.Min()))
  26. stathat.PostEZValue(name+".max", userkey, float64(m.Max()))
  27. stathat.PostEZValue(name+".mean", userkey, float64(m.Mean()))
  28. stathat.PostEZValue(name+".std-dev", userkey, float64(m.StdDev()))
  29. stathat.PostEZValue(name+".50-percentile", userkey, float64(ps[0]))
  30. stathat.PostEZValue(name+".75-percentile", userkey, float64(ps[1]))
  31. stathat.PostEZValue(name+".95-percentile", userkey, float64(ps[2]))
  32. stathat.PostEZValue(name+".99-percentile", userkey, float64(ps[3]))
  33. stathat.PostEZValue(name+".999-percentile", userkey, float64(ps[4]))
  34. case Meter:
  35. stathat.PostEZCount(name+".count", userkey, int(m.Count()))
  36. stathat.PostEZValue(name+".one-minute", userkey, float64(m.Rate1()))
  37. stathat.PostEZValue(name+".five-minute", userkey, float64(m.Rate5()))
  38. stathat.PostEZValue(name+".fifteen-minute", userkey, float64(m.Rate15()))
  39. stathat.PostEZValue(name+".mean", userkey, float64(m.RateMean()))
  40. case Timer:
  41. ps := m.Percentiles([]float64{0.5, 0.75, 0.95, 0.99, 0.999})
  42. stathat.PostEZCount(name+".count", userkey, int(m.Count()))
  43. stathat.PostEZValue(name+".min", userkey, float64(m.Min()))
  44. stathat.PostEZValue(name+".max", userkey, float64(m.Max()))
  45. stathat.PostEZValue(name+".mean", userkey, float64(m.Mean()))
  46. stathat.PostEZValue(name+".std-dev", userkey, float64(m.StdDev()))
  47. stathat.PostEZValue(name+".50-percentile", userkey, float64(ps[0]))
  48. stathat.PostEZValue(name+".75-percentile", userkey, float64(ps[1]))
  49. stathat.PostEZValue(name+".95-percentile", userkey, float64(ps[2]))
  50. stathat.PostEZValue(name+".99-percentile", userkey, float64(ps[3]))
  51. stathat.PostEZValue(name+".999-percentile", userkey, float64(ps[4]))
  52. stathat.PostEZValue(name+".one-minute", userkey, float64(m.Rate1()))
  53. stathat.PostEZValue(name+".five-minute", userkey, float64(m.Rate5()))
  54. stathat.PostEZValue(name+".fifteen-minute", userkey, float64(m.Rate15()))
  55. stathat.PostEZValue(name+".mean", userkey, float64(m.RateMean()))
  56. }
  57. })
  58. return nil
  59. }