Keine Beschreibung

Richard Crowley 4461e83a4e Cleanup imports. vor 14 Jahren
cmd a31ebf206b Use time.Ticker to avoid bajillions of threads. vor 14 Jahren
.gitignore 0818b952c0 Removed a binary. vor 14 Jahren
LICENSE f7cf4d7405 Initial import. vor 14 Jahren
Makefile 1f505b2fae Crude memory usage benchmarks. vor 14 Jahren
README.md 033e0dc4eb Installation and usage. vor 14 Jahren
counter.go 9192d930ec Use atomics for counters and gauges. vor 14 Jahren
counter_test.go 4461e83a4e Cleanup imports. vor 14 Jahren
ewma.go 93a07b730f More memory-efficient meters. vor 14 Jahren
ewma_test.go 4461e83a4e Cleanup imports. vor 14 Jahren
gauge.go 9192d930ec Use atomics for counters and gauges. vor 14 Jahren
gauge_test.go 4461e83a4e Cleanup imports. vor 14 Jahren
healthcheck.go 4461e83a4e Cleanup imports. vor 14 Jahren
histogram.go 42de9db64b Percentiles are zero in empty histograms. vor 14 Jahren
histogram_test.go 4461e83a4e Cleanup imports. vor 14 Jahren
log.go 0f101b213d Added Log and Syslog functions that print metrics. vor 14 Jahren
memory.md 033e0dc4eb Installation and usage. vor 14 Jahren
meter.go 4461e83a4e Cleanup imports. vor 14 Jahren
meter_test.go 4461e83a4e Cleanup imports. vor 14 Jahren
metrics.go f7cf4d7405 Initial import. vor 14 Jahren
registry.go 98d790c9a2 Added Unregister* methods. vor 14 Jahren
sample.go f068d88f36 Correct timestamp usage in exponential decay. vor 14 Jahren
sample_test.go 4461e83a4e Cleanup imports. vor 14 Jahren
syslog.go 0f101b213d Added Log and Syslog functions that print metrics. vor 14 Jahren
timer.go f7cf4d7405 Initial import. vor 14 Jahren

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.

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("bang", m)
m.Mark(47)

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