بدون توضیح

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

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