| 1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465 |
- package metrics
- import (
- "bufio"
- "fmt"
- "net"
- "time"
- )
- func Graphite(r Registry, interval int, addr string) {
- for {
- time.Sleep(time.Duration(int64(1e9) * int64(interval)))
- now := time.Now().Unix()
- conn, err := net.Dial("tcp", addr)
- if err != nil {
- continue
- }
- w := bufio.NewWriter(conn)
- r.Each(func(name string, i interface{}) {
- switch m := i.(type) {
- case Counter:
- w.WriteString(fmt.Sprintf("%s.count %d %d\n", name, m.Count(), now))
- case Gauge:
- w.WriteString(fmt.Sprintf("%s.value %d %d\n", name, m.Value(), now))
- case Histogram:
- ps := m.Percentiles([]float64{0.5, 0.75, 0.95, 0.99, 0.999})
- w.WriteString(fmt.Sprintf("%s.count %d %d\n", name, m.Count(), now))
- w.WriteString(fmt.Sprintf("%s.min %d %d\n", name, m.Min(), now))
- w.WriteString(fmt.Sprintf("%s.max %d %d\n", name, m.Max(), now))
- w.WriteString(fmt.Sprintf("%s.mean %.2f %d\n", name, m.Mean(), now))
- w.WriteString(fmt.Sprintf("%s.std-dev %.2f %d\n", name, m.StdDev(), now))
- w.WriteString(fmt.Sprintf("%s.50-percentile %.2f %d\n", name, ps[0], now))
- w.WriteString(fmt.Sprintf("%s.75-percentile %.2f %d\n", name, ps[1], now))
- w.WriteString(fmt.Sprintf("%s.95-percentile %.2f %d\n", name, ps[2], now))
- w.WriteString(fmt.Sprintf("%s.99-percentile %.2f %d\n", name, ps[3], now))
- w.WriteString(fmt.Sprintf("%s.999-percentile %.2f %d\n", name, ps[4], now))
- case Meter:
- w.WriteString(fmt.Sprintf("%s.count %d %d\n", name, m.Count(), now))
- w.WriteString(fmt.Sprintf("%s.one-minute %.2f %d\n", name, m.Rate1(), now))
- w.WriteString(fmt.Sprintf("%s.five-minute %.2f %d\n", name, m.Rate5(), now))
- w.WriteString(fmt.Sprintf("%s.fifteen-minute %.2f %d\n", name, m.Rate15(), now))
- w.WriteString(fmt.Sprintf("%s.mean %.2f %d\n", name, m.RateMean(), now))
- case Timer:
- ps := m.Percentiles([]float64{0.5, 0.75, 0.95, 0.99, 0.999})
- w.WriteString(fmt.Sprintf("%s.count %d %d\n", name, m.Count(), now))
- w.WriteString(fmt.Sprintf("%s.min %d %d\n", name, m.Min(), now))
- w.WriteString(fmt.Sprintf("%s.max %d %d\n", name, m.Max(), now))
- w.WriteString(fmt.Sprintf("%s.mean %.2f %d\n", name, m.Mean(), now))
- w.WriteString(fmt.Sprintf("%s.std-dev %.2f %d\n", name, m.StdDev(), now))
- w.WriteString(fmt.Sprintf("%s.50-percentile %.2f %d\n", name, ps[0], now))
- w.WriteString(fmt.Sprintf("%s.75-percentile %.2f %d\n", name, ps[1], now))
- w.WriteString(fmt.Sprintf("%s.95-percentile %.2f %d\n", name, ps[2], now))
- w.WriteString(fmt.Sprintf("%s.99-percentile %.2f %d\n", name, ps[3], now))
- w.WriteString(fmt.Sprintf("%s.999-percentile %.2f %d\n", name, ps[4], now))
- w.WriteString(fmt.Sprintf("%s.one-minute %.2f %d\n", name, m.Rate1(), now))
- w.WriteString(fmt.Sprintf("%s.five-minute %.2f %d\n", name, m.Rate5(), now))
- w.WriteString(fmt.Sprintf("%s.fifteen-minute %.2f %d\n", name, m.Rate15(), now))
- w.WriteString(fmt.Sprintf("%s.mean %.2f %d\n", name, m.RateMean(), now))
- }
- w.Flush()
- })
- }
- }
|