Sin descripción

Richard Crowley 2e75e03390 Register runtime.MemStats metrics. hace 14 años
cmd 2e75e03390 Register runtime.MemStats metrics. hace 14 años
.gitignore f034a3e966 Don't commit binaries, dummy. hace 14 años
LICENSE f7cf4d7405 Initial import. hace 14 años
Makefile 2e75e03390 Register runtime.MemStats metrics. hace 14 años
README.md 0a43520f8b Timer example. hace 14 años
counter.go fa13d02e11 Export more names for godoc's sake. hace 14 años
counter_test.go 4461e83a4e Cleanup imports. hace 14 años
ewma.go fa13d02e11 Export more names for godoc's sake. hace 14 años
ewma_test.go 4461e83a4e Cleanup imports. hace 14 años
gauge.go 325de57872 Silence unused import. hace 14 años
gauge_test.go 4461e83a4e Cleanup imports. hace 14 años
healthcheck.go fa13d02e11 Export more names for godoc's sake. hace 14 años
histogram.go fa13d02e11 Export more names for godoc's sake. hace 14 años
histogram_test.go 4461e83a4e Cleanup imports. hace 14 años
log.go af687e233a Comments for godoc. hace 14 años
memory.md 033e0dc4eb Installation and usage. hace 14 años
meter.go fa13d02e11 Export more names for godoc's sake. hace 14 años
meter_test.go 4461e83a4e Cleanup imports. hace 14 años
metrics.go f7cf4d7405 Initial import. hace 14 años
registry.go fa13d02e11 Export more names for godoc's sake. hace 14 años
runtime.go 2e75e03390 Register runtime.MemStats metrics. hace 14 años
sample.go fa13d02e11 Export more names for godoc's sake. hace 14 años
sample_test.go 4461e83a4e Cleanup imports. hace 14 años
syslog.go af687e233a Comments for godoc. hace 14 años
timer.go fa13d02e11 Export more names for godoc's sake. hace 14 años
timer_test.go c64d95acf6 Added Timer metrics. hace 14 años

README.md

go-metrics

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

This code is not safe on 32-bit architectures. It will be as soon as atomic.LoadInt64 lands in a release tag.

Usage

Create and update metrics:

r := metrics.NewRegistry()

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

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

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

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

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

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

metrics.Log(r, 60, log.New(os.Stderr, "metrics: ", log.Lmicroseconds))

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

w, err := syslog.Dial("unixgram", "/dev/log", syslog.LOG_INFO, "metrics")
if nil != err { log.Fatalln(err) }
metrics.Syslog(r, 60, w)

Installation

goinstall github.com/rcrowley/go-metrics