Sin descripción

Richard Crowley 603c96db48 go fmt hace 12 años
cmd 49f54c6efe Update for the new interface. hace 12 años
.gitignore af31e2573f Alphabetical order. hace 14 años
LICENSE cf3de86166 Updated docs, deleted Makefiles. hace 14 años
README.md 74e8d102db Clarify in the README that the "outputs" do not return hace 12 años
counter.go 07ad690f21 Interface checks all over. hace 12 años
counter_test.go 4461e83a4e Cleanup imports. hace 14 años
ewma.go 07ad690f21 Interface checks all over. hace 12 años
ewma_test.go 15d638721f gofmt hace 13 años
gauge.go 07ad690f21 Interface checks all over. hace 12 años
gauge_test.go 4461e83a4e Cleanup imports. hace 14 años
graphite.go 73a2e512a7 Add a prefix to Graphite metrics. hace 13 años
healthcheck.go 07ad690f21 Interface checks all over. hace 12 años
histogram.go 07ad690f21 Interface checks all over. hace 12 años
histogram_test.go 15d638721f gofmt hace 13 años
json.go 933470e6a2 Merge branch 'arikfb-master' hace 12 años
log.go 10c63bdfe9 gofix hace 14 años
memory.md 033e0dc4eb Installation and usage. hace 14 años
meter.go 07ad690f21 Interface checks all over. hace 12 años
meter_test.go 4461e83a4e Cleanup imports. hace 14 años
metrics.go f7cf4d7405 Initial import. hace 14 años
registry.go 603c96db48 go fmt hace 12 años
runtime.go 88ddcecc4f Way more correct PauseNs. hace 13 años
sample.go 07ad690f21 Interface checks all over. hace 12 años
sample_test.go ef6ff7cde4 Fix bug that ignores one sample in UniformSample hace 13 años
syslog.go 60ba4ca70c don't build syslog on windows hace 12 años
timer.go 07ad690f21 Interface checks all over. hace 12 años
timer_test.go e0ec3c8081 Add UpdateSince for use with defer. hace 13 años

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, 60, 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, 60, w)

Periodically emit every metric to Graphite:

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

Installation

go get github.com/rcrowley/go-metrics