Нет описания

Richard Crowley 933470e6a2 Merge branch 'arikfb-master' 12 лет назад
cmd 49f54c6efe Update for the new interface. 13 лет назад
.gitignore af31e2573f Alphabetical order. 14 лет назад
LICENSE cf3de86166 Updated docs, deleted Makefiles. 14 лет назад
README.md 74e8d102db Clarify in the README that the "outputs" do not return 13 лет назад
counter.go 07ad690f21 Interface checks all over. 13 лет назад
counter_test.go 4461e83a4e Cleanup imports. 14 лет назад
ewma.go 07ad690f21 Interface checks all over. 13 лет назад
ewma_test.go 15d638721f gofmt 13 лет назад
gauge.go 07ad690f21 Interface checks all over. 13 лет назад
gauge_test.go 4461e83a4e Cleanup imports. 14 лет назад
graphite.go 73a2e512a7 Add a prefix to Graphite metrics. 13 лет назад
healthcheck.go 07ad690f21 Interface checks all over. 13 лет назад
histogram.go 07ad690f21 Interface checks all over. 13 лет назад
histogram_test.go 15d638721f gofmt 13 лет назад
json.go 933470e6a2 Merge branch 'arikfb-master' 12 лет назад
log.go 10c63bdfe9 gofix 14 лет назад
memory.md 033e0dc4eb Installation and usage. 14 лет назад
meter.go 07ad690f21 Interface checks all over. 13 лет назад
meter_test.go 4461e83a4e Cleanup imports. 14 лет назад
metrics.go f7cf4d7405 Initial import. 14 лет назад
registry.go 07ad690f21 Interface checks all over. 13 лет назад
runtime.go 88ddcecc4f Way more correct PauseNs. 13 лет назад
sample.go 07ad690f21 Interface checks all over. 13 лет назад
sample_test.go ef6ff7cde4 Fix bug that ignores one sample in UniformSample 13 лет назад
syslog.go 60ba4ca70c don't build syslog on windows 13 лет назад
timer.go 07ad690f21 Interface checks all over. 13 лет назад
timer_test.go e0ec3c8081 Add UpdateSince for use with defer. 13 лет назад

README.md

go-metrics

Go port of Coda Hale's Metrics library: https://github.com/codahale/metrics.

Documentation: http://godoc.org/github.com/rcrowley/go-metrics.

Usage

Create and update metrics:

c := metrics.NewCounter()
metrics.Register("foo", c)
c.Inc(47)

g := metrics.NewGauge()
metrics.Register("bar", g)
g.Update(47)

s := metrics.NewExpDecaySample(1028, 0.015) // or metrics.NewUniformSample(1028)
h := metrics.NewHistogram(s)
metrics.Register("baz", h)
h.Update(47)

m := metrics.NewMeter()
metrics.Register("quux", m)
m.Mark(47)

t := metrics.NewTimer()
metrics.Register("bang", t)
t.Time(func() {})
t.Update(47)

Periodically log every metric in human-readable form to standard error:

go metrics.Log(metrics.DefaultRegistry, 60, log.New(os.Stderr, "metrics: ", log.Lmicroseconds))

Periodically log every metric in slightly-more-parseable form to syslog:

w, _ := syslog.Dial("unixgram", "/dev/log", syslog.LOG_INFO, "metrics")
go metrics.Syslog(metrics.DefaultRegistry, 60, w)

Periodically emit every metric to Graphite:

addr, _ := net.ResolveTCPAddr("tcp", "127.0.0.1:2003")
go metrics.Graphite(metrics.DefaultRegistry, 10, "metrics", addr)

Installation

go get github.com/rcrowley/go-metrics