Ei kuvausta

Timothée Peignier d49e4bf247 add graphite reporter 13 vuotta sitten
cmd cf3de86166 Updated docs, deleted Makefiles. 14 vuotta sitten
.gitignore af31e2573f Alphabetical order. 14 vuotta sitten
LICENSE cf3de86166 Updated docs, deleted Makefiles. 14 vuotta sitten
README.md cf3de86166 Updated docs, deleted Makefiles. 14 vuotta sitten
counter.go 7598ab361f Make metrics 32-bit safe 14 vuotta sitten
counter_test.go 4461e83a4e Cleanup imports. 14 vuotta sitten
ewma.go 16e21f79d4 Merge branch '32bit_safety' 14 vuotta sitten
ewma_test.go 4461e83a4e Cleanup imports. 14 vuotta sitten
gauge.go 7598ab361f Make metrics 32-bit safe 14 vuotta sitten
gauge_test.go 4461e83a4e Cleanup imports. 14 vuotta sitten
graphite.go d49e4bf247 add graphite reporter 13 vuotta sitten
healthcheck.go 10c63bdfe9 gofix 14 vuotta sitten
histogram.go 87f4f4a3a2 As Roger Peppe suggested, return concrete types. 14 vuotta sitten
histogram_test.go 4461e83a4e Cleanup imports. 14 vuotta sitten
log.go 10c63bdfe9 gofix 14 vuotta sitten
memory.md 033e0dc4eb Installation and usage. 14 vuotta sitten
meter.go 10c63bdfe9 gofix 14 vuotta sitten
meter_test.go 4461e83a4e Cleanup imports. 14 vuotta sitten
metrics.go f7cf4d7405 Initial import. 14 vuotta sitten
registry.go 10c63bdfe9 gofix 14 vuotta sitten
runtime.go 0029c34060 Update for Go 1. 14 vuotta sitten
sample.go 10c63bdfe9 gofix 14 vuotta sitten
sample_test.go 4461e83a4e Cleanup imports. 14 vuotta sitten
syslog.go 10c63bdfe9 gofix 14 vuotta sitten
timer.go 10c63bdfe9 gofix 14 vuotta sitten
timer_test.go c64d95acf6 Added Timer metrics. 14 vuotta sitten

README.md

go-metrics

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

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

go install github.com/rcrowley/go-metrics