No Description

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

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