Nav apraksta

Stuart Carnie 6d82eb1add Added JSON->io.Writer; consistent ordering to WriteOnce 11 gadi atpakaļ
cmd 68b130797a initial implementation of GaugeFloat64 11 gadi atpakaļ
influxdb 68b130797a initial implementation of GaugeFloat64 11 gadi atpakaļ
librato 68b130797a initial implementation of GaugeFloat64 11 gadi atpakaļ
stathat 68b130797a initial implementation of GaugeFloat64 11 gadi atpakaļ
.gitignore 7b8f3191d7 never-read debugging tool. 12 gadi atpakaļ
LICENSE cf3de86166 Updated docs, deleted Makefiles. 13 gadi atpakaļ
README.md 6a64674220 Style: alphabetize, gofmt, etc. 11 gadi atpakaļ
counter.go b29332614c Allow lazy instantiation of metric in GetOrRegister. 11 gadi atpakaļ
counter_test.go 10aaf9c455 Fully introduce snapshots for all metric types. 12 gadi atpakaļ
debug.go a9f31ff475 Research, benchmarks, and tests. 12 gadi atpakaļ
debug_test.go a4a3178f75 Skip tests that require GOMAXPROCS > 1. 12 gadi atpakaļ
ewma.go f9ee67ed7c ewma: ensure 64-bit alignment of uncounted 12 gadi atpakaļ
ewma_test.go ddac18df1e Benchmarks for everyone! 12 gadi atpakaļ
gauge.go b29332614c Allow lazy instantiation of metric in GetOrRegister. 11 gadi atpakaļ
gauge_float64.go 37df06ff62 Do not export methods from sync.Mutex on gauges. 11 gadi atpakaļ
gauge_float64_test.go 52781178b7 Tidying whitespace. 11 gadi atpakaļ
gauge_test.go 10aaf9c455 Fully introduce snapshots for all metric types. 12 gadi atpakaļ
graphite.go 68b130797a initial implementation of GaugeFloat64 11 gadi atpakaļ
graphite_test.go 320b17dad3 Merge branch 'graphite-config' 12 gadi atpakaļ
healthcheck.go 6bd8d76861 Mostly documentation and naming changes. 12 gadi atpakaļ
histogram.go b29332614c Allow lazy instantiation of metric in GetOrRegister. 11 gadi atpakaļ
histogram_test.go 6fa35ede17 Fix tests broken by sample changes. 12 gadi atpakaļ
json.go 6d82eb1add Added JSON->io.Writer; consistent ordering to WriteOnce 11 gadi atpakaļ
json_test.go 6d82eb1add Added JSON->io.Writer; consistent ordering to WriteOnce 11 gadi atpakaļ
log.go 68b130797a initial implementation of GaugeFloat64 11 gadi atpakaļ
memory.md 033e0dc4eb Installation and usage. 14 gadi atpakaļ
meter.go c3b4f6b241 Style. 11 gadi atpakaļ
meter_test.go 0c229a5e1b Use a single goroutine for meters. 11 gadi atpakaļ
metrics.go 6d82eb1add Added JSON->io.Writer; consistent ordering to WriteOnce 11 gadi atpakaļ
metrics_test.go 6d82eb1add Added JSON->io.Writer; consistent ordering to WriteOnce 11 gadi atpakaļ
opentsdb.go 490281a63d add opentsdb support 11 gadi atpakaļ
opentsdb_test.go 490281a63d add opentsdb support 11 gadi atpakaļ
registry.go f51a76fc35 Fix infinite loop in DuplicateMetric.Error 11 gadi atpakaļ
registry_test.go 426a4331b7 Return an error from Register and disallow dupes 11 gadi atpakaļ
runtime.go 10272f002f Rework NumGC and PauseNs runtime metrics. 11 gadi atpakaļ
runtime_test.go 10272f002f Rework NumGC and PauseNs runtime metrics. 11 gadi atpakaļ
sample.go 129a585260 Calculate all histogram statistics from samples. 12 gadi atpakaļ
sample_test.go 10aaf9c455 Fully introduce snapshots for all metric types. 12 gadi atpakaļ
syslog.go 68b130797a initial implementation of GaugeFloat64 11 gadi atpakaļ
timer.go b29332614c Allow lazy instantiation of metric in GetOrRegister. 11 gadi atpakaļ
timer_test.go 6fa35ede17 Fix tests broken by sample changes. 12 gadi atpakaļ
writer.go 6d82eb1add Added JSON->io.Writer; consistent ordering to WriteOnce 11 gadi atpakaļ

README.md

go-metrics

Go port of Coda Hale's Metrics library: https://github.com/codahale/metrics.

Documentation: http://godoc.org/github.com/rcrowley/go-metrics.

Usage

Create and update metrics:

c := metrics.NewCounter()
metrics.Register("foo", c)
c.Inc(47)

g := metrics.NewGauge()
metrics.Register("bar", g)
g.Update(47)

s := metrics.NewExpDecaySample(1028, 0.015) // or metrics.NewUniformSample(1028)
h := metrics.NewHistogram(s)
metrics.Register("baz", h)
h.Update(47)

m := metrics.NewMeter()
metrics.Register("quux", m)
m.Mark(47)

t := metrics.NewTimer()
metrics.Register("bang", t)
t.Time(func() {})
t.Update(47)

Periodically log every metric in human-readable form to standard error:

go metrics.Log(metrics.DefaultRegistry, 60e9, log.New(os.Stderr, "metrics: ", log.Lmicroseconds))

Periodically log every metric in slightly-more-parseable form to syslog:

w, _ := syslog.Dial("unixgram", "/dev/log", syslog.LOG_INFO, "metrics")
go metrics.Syslog(metrics.DefaultRegistry, 60e9, w)

Periodically emit every metric to Graphite:

addr, _ := net.ResolveTCPAddr("tcp", "127.0.0.1:2003")
go metrics.Graphite(metrics.DefaultRegistry, 10e9, "metrics", addr)

Periodically emit every metric into InfluxDB:

import "github.com/rcrowley/go-metrics/influxdb"

go influxdb.Influxdb(metrics.DefaultRegistry, 10e9, &influxdb.Config{
    Host:     "127.0.0.1:8086",
    Database: "metrics",
    Username: "test",
    Password: "test",
})

Periodically upload every metric to Librato:

import "github.com/rcrowley/go-metrics/librato"

go librato.Librato(metrics.DefaultRegistry,
    10e9,                  // interval
    "example@example.com", // account owner email address
    "token",               // Librato API token
    "hostname",            // source
    []float64{95},         // precentiles to send
    time.Millisecond,      // time unit
)

Periodically emit every metric to StatHat:

import "github.com/rcrowley/go-metrics/stathat"

go stathat.Stathat(metrics.DefaultRegistry, 10e9, "example@example.com")

Installation

go get github.com/rcrowley/go-metrics

StatHat support additionally requires their Go client:

go get github.com/stathat/go