graphite.go 2.9 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465
  1. package metrics
  2. import (
  3. "bufio"
  4. "fmt"
  5. "net"
  6. "time"
  7. )
  8. func Graphite(r Registry, interval int, addr string) {
  9. for {
  10. time.Sleep(time.Duration(int64(1e9) * int64(interval)))
  11. now := time.Now().Unix()
  12. conn, err := net.Dial("tcp", addr)
  13. if err != nil {
  14. continue
  15. }
  16. w := bufio.NewWriter(conn)
  17. r.Each(func(name string, i interface{}) {
  18. switch m := i.(type) {
  19. case Counter:
  20. w.WriteString(fmt.Sprintf("%s.count %d %d\n", name, m.Count(), now))
  21. case Gauge:
  22. w.WriteString(fmt.Sprintf("%s.value %d %d\n", name, m.Value(), now))
  23. case Histogram:
  24. ps := m.Percentiles([]float64{0.5, 0.75, 0.95, 0.99, 0.999})
  25. w.WriteString(fmt.Sprintf("%s.count %d %d\n", name, m.Count(), now))
  26. w.WriteString(fmt.Sprintf("%s.min %d %d\n", name, m.Min(), now))
  27. w.WriteString(fmt.Sprintf("%s.max %d %d\n", name, m.Max(), now))
  28. w.WriteString(fmt.Sprintf("%s.mean %.2f %d\n", name, m.Mean(), now))
  29. w.WriteString(fmt.Sprintf("%s.std-dev %.2f %d\n", name, m.StdDev(), now))
  30. w.WriteString(fmt.Sprintf("%s.50-percentile %.2f %d\n", name, ps[0], now))
  31. w.WriteString(fmt.Sprintf("%s.75-percentile %.2f %d\n", name, ps[1], now))
  32. w.WriteString(fmt.Sprintf("%s.95-percentile %.2f %d\n", name, ps[2], now))
  33. w.WriteString(fmt.Sprintf("%s.99-percentile %.2f %d\n", name, ps[3], now))
  34. w.WriteString(fmt.Sprintf("%s.999-percentile %.2f %d\n", name, ps[4], now))
  35. case Meter:
  36. w.WriteString(fmt.Sprintf("%s.count %d %d\n", name, m.Count(), now))
  37. w.WriteString(fmt.Sprintf("%s.one-minute %.2f %d\n", name, m.Rate1(), now))
  38. w.WriteString(fmt.Sprintf("%s.five-minute %.2f %d\n", name, m.Rate5(), now))
  39. w.WriteString(fmt.Sprintf("%s.fifteen-minute %.2f %d\n", name, m.Rate15(), now))
  40. w.WriteString(fmt.Sprintf("%s.mean %.2f %d\n", name, m.RateMean(), now))
  41. case Timer:
  42. ps := m.Percentiles([]float64{0.5, 0.75, 0.95, 0.99, 0.999})
  43. w.WriteString(fmt.Sprintf("%s.count %d %d\n", name, m.Count(), now))
  44. w.WriteString(fmt.Sprintf("%s.min %d %d\n", name, m.Min(), now))
  45. w.WriteString(fmt.Sprintf("%s.max %d %d\n", name, m.Max(), now))
  46. w.WriteString(fmt.Sprintf("%s.mean %.2f %d\n", name, m.Mean(), now))
  47. w.WriteString(fmt.Sprintf("%s.std-dev %.2f %d\n", name, m.StdDev(), now))
  48. w.WriteString(fmt.Sprintf("%s.50-percentile %.2f %d\n", name, ps[0], now))
  49. w.WriteString(fmt.Sprintf("%s.75-percentile %.2f %d\n", name, ps[1], now))
  50. w.WriteString(fmt.Sprintf("%s.95-percentile %.2f %d\n", name, ps[2], now))
  51. w.WriteString(fmt.Sprintf("%s.99-percentile %.2f %d\n", name, ps[3], now))
  52. w.WriteString(fmt.Sprintf("%s.999-percentile %.2f %d\n", name, ps[4], now))
  53. w.WriteString(fmt.Sprintf("%s.one-minute %.2f %d\n", name, m.Rate1(), now))
  54. w.WriteString(fmt.Sprintf("%s.five-minute %.2f %d\n", name, m.Rate5(), now))
  55. w.WriteString(fmt.Sprintf("%s.fifteen-minute %.2f %d\n", name, m.Rate15(), now))
  56. w.WriteString(fmt.Sprintf("%s.mean %.2f %d\n", name, m.RateMean(), now))
  57. }
  58. w.Flush()
  59. })
  60. }
  61. }