Žiadny popis

Richard Crowley 356378cef5 That's not how gauges work. 14 rokov pred
cmd f034a3e966 Don't commit binaries, dummy. 14 rokov pred
.gitignore f034a3e966 Don't commit binaries, dummy. 14 rokov pred
LICENSE f7cf4d7405 Initial import. 14 rokov pred
Makefile 8b1a49ea96 Use library with GitHub path. 14 rokov pred
README.md 0a43520f8b Timer example. 14 rokov pred
counter.go fa13d02e11 Export more names for godoc's sake. 14 rokov pred
counter_test.go 4461e83a4e Cleanup imports. 14 rokov pred
ewma.go fa13d02e11 Export more names for godoc's sake. 14 rokov pred
ewma_test.go 4461e83a4e Cleanup imports. 14 rokov pred
gauge.go 356378cef5 That's not how gauges work. 14 rokov pred
gauge_test.go 4461e83a4e Cleanup imports. 14 rokov pred
healthcheck.go fa13d02e11 Export more names for godoc's sake. 14 rokov pred
histogram.go fa13d02e11 Export more names for godoc's sake. 14 rokov pred
histogram_test.go 4461e83a4e Cleanup imports. 14 rokov pred
log.go af687e233a Comments for godoc. 14 rokov pred
memory.md 033e0dc4eb Installation and usage. 14 rokov pred
meter.go fa13d02e11 Export more names for godoc's sake. 14 rokov pred
meter_test.go 4461e83a4e Cleanup imports. 14 rokov pred
metrics.go f7cf4d7405 Initial import. 14 rokov pred
registry.go fa13d02e11 Export more names for godoc's sake. 14 rokov pred
sample.go fa13d02e11 Export more names for godoc's sake. 14 rokov pred
sample_test.go 4461e83a4e Cleanup imports. 14 rokov pred
syslog.go af687e233a Comments for godoc. 14 rokov pred
timer.go fa13d02e11 Export more names for godoc's sake. 14 rokov pred
timer_test.go c64d95acf6 Added Timer metrics. 14 rokov pred

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