Bez popisu

Richard Crowley ea09f7d79b Merge pull request #38 from crosbymichael/influxdb-backend před 12 roky
cmd 6c9cbbbec4 (#22) Refactor StatHat support into its own package. před 12 roky
influxdb 7f902fb874 Add influxdb backend před 12 roky
librato b7b6bfd002 Merge branch 'samples' před 12 roky
stathat 1566254dae Use snapshots in all the reporters. před 12 roky
.gitignore 7b8f3191d7 never-read debugging tool. před 12 roky
LICENSE cf3de86166 Updated docs, deleted Makefiles. před 14 roky
README.md 7f902fb874 Add influxdb backend před 12 roky
counter.go 10aaf9c455 Fully introduce snapshots for all metric types. před 12 roky
counter_test.go 10aaf9c455 Fully introduce snapshots for all metric types. před 12 roky
debug.go a9f31ff475 Research, benchmarks, and tests. před 12 roky
debug_test.go a4a3178f75 Skip tests that require GOMAXPROCS > 1. před 12 roky
ewma.go f9ee67ed7c ewma: ensure 64-bit alignment of uncounted před 12 roky
ewma_test.go ddac18df1e Benchmarks for everyone! před 12 roky
gauge.go 10aaf9c455 Fully introduce snapshots for all metric types. před 12 roky
gauge_test.go 10aaf9c455 Fully introduce snapshots for all metric types. před 12 roky
graphite.go 320b17dad3 Merge branch 'graphite-config' před 12 roky
graphite_test.go 320b17dad3 Merge branch 'graphite-config' před 12 roky
healthcheck.go 6bd8d76861 Mostly documentation and naming changes. před 12 roky
histogram.go 129a585260 Calculate all histogram statistics from samples. před 12 roky
histogram_test.go 6fa35ede17 Fix tests broken by sample changes. před 12 roky
json.go 1566254dae Use snapshots in all the reporters. před 12 roky
log.go 1566254dae Use snapshots in all the reporters. před 12 roky
memory.md 033e0dc4eb Installation and usage. před 14 roky
meter.go 10aaf9c455 Fully introduce snapshots for all metric types. před 12 roky
meter_test.go 10aaf9c455 Fully introduce snapshots for all metric types. před 12 roky
metrics.go b953f7c0d8 ETOOCLEVER so s/ObserverEffect/UseNilMetrics/. před 12 roky
metrics_test.go ab878ebe34 go fmt před 12 roky
registry.go 569c4a2ce0 GetOrRegister for the DefaultRegistry. před 12 roky
registry_test.go 880a57cfbc Test reference behavior of metrics in a Registry. před 12 roky
runtime.go a9f31ff475 Research, benchmarks, and tests. před 12 roky
runtime_test.go a4a3178f75 Skip tests that require GOMAXPROCS > 1. před 12 roky
sample.go 129a585260 Calculate all histogram statistics from samples. před 12 roky
sample_test.go 10aaf9c455 Fully introduce snapshots for all metric types. před 12 roky
syslog.go 1566254dae Use snapshots in all the reporters. před 12 roky
timer.go 10aaf9c455 Fully introduce snapshots for all metric types. před 12 roky
timer_test.go 6fa35ede17 Fix tests broken by sample changes. před 12 roky
writer.go 1566254dae Use snapshots in all the reporters. před 12 roky

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, 60e9, 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, 60e9, w)

Periodically emit every metric to Graphite:

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

Periodically emit every metric to StatHat:

import "github.com/rcrowley/go-metrics/stathat"

stathat.Stathat(metrics.DefaultRegistry, 10e9, "example@example.com")

Periodically emit every metric into Influxdb:

import "github.com/rcrowley/go-metrics/influxdb"

go influxdb.Influxdb(metrics.DefaultRegistry, 10e9, &influxdb.Config{
    Host:     "127.0.0.1:8086",
    Database: "metrics",
    Username: "test",
    Password: "test",
})

Installation

go get github.com/rcrowley/go-metrics

StatHat support additionally requires their Go client:

go get github.com/stathat/go