stathat.go 2.9 KB

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