Nav apraksta

Richard Crowley ba9d0e442c Merge pull request #2 from cyberdelia/graphite-output 13 gadi atpakaļ
cmd cf3de86166 Updated docs, deleted Makefiles. 14 gadi atpakaļ
.gitignore af31e2573f Alphabetical order. 14 gadi atpakaļ
LICENSE cf3de86166 Updated docs, deleted Makefiles. 14 gadi atpakaļ
README.md cf3de86166 Updated docs, deleted Makefiles. 14 gadi atpakaļ
counter.go 7598ab361f Make metrics 32-bit safe 14 gadi atpakaļ
counter_test.go 4461e83a4e Cleanup imports. 14 gadi atpakaļ
ewma.go 16e21f79d4 Merge branch '32bit_safety' 14 gadi atpakaļ
ewma_test.go 4461e83a4e Cleanup imports. 14 gadi atpakaļ
gauge.go 7598ab361f Make metrics 32-bit safe 14 gadi atpakaļ
gauge_test.go 4461e83a4e Cleanup imports. 14 gadi atpakaļ
graphite.go 624e661e0a avoid reconnecting without waiting 13 gadi atpakaļ
healthcheck.go 10c63bdfe9 gofix 14 gadi atpakaļ
histogram.go 87f4f4a3a2 As Roger Peppe suggested, return concrete types. 14 gadi atpakaļ
histogram_test.go 4461e83a4e Cleanup imports. 14 gadi atpakaļ
log.go 10c63bdfe9 gofix 14 gadi atpakaļ
memory.md 033e0dc4eb Installation and usage. 14 gadi atpakaļ
meter.go 10c63bdfe9 gofix 14 gadi atpakaļ
meter_test.go 4461e83a4e Cleanup imports. 14 gadi atpakaļ
metrics.go f7cf4d7405 Initial import. 14 gadi atpakaļ
registry.go 10c63bdfe9 gofix 14 gadi atpakaļ
runtime.go 0029c34060 Update for Go 1. 14 gadi atpakaļ
sample.go 10c63bdfe9 gofix 14 gadi atpakaļ
sample_test.go 4461e83a4e Cleanup imports. 14 gadi atpakaļ
syslog.go 10c63bdfe9 gofix 14 gadi atpakaļ
timer.go 10c63bdfe9 gofix 14 gadi atpakaļ
timer_test.go c64d95acf6 Added Timer metrics. 14 gadi atpakaļ

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