Brak opisu

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

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