Ingen beskrivning

Attila Oláh f47ededb99 use a time.Ticker instead of the time.Sleep 11 år sedan
cmd 68b130797a initial implementation of GaugeFloat64 11 år sedan
influxdb 0f75ec011f Update influxdb.go 11 år sedan
librato 1f6faa4de7 do not shadow return value 11 år sedan
stathat 68b130797a initial implementation of GaugeFloat64 11 år sedan
.gitignore 7b8f3191d7 never-read debugging tool. 12 år sedan
LICENSE cf3de86166 Updated docs, deleted Makefiles. 14 år sedan
README.md 6a64674220 Style: alphabetize, gofmt, etc. 11 år sedan
counter.go b29332614c Allow lazy instantiation of metric in GetOrRegister. 11 år sedan
counter_test.go 10aaf9c455 Fully introduce snapshots for all metric types. 12 år sedan
debug.go a9f31ff475 Research, benchmarks, and tests. 12 år sedan
debug_test.go a4a3178f75 Skip tests that require GOMAXPROCS > 1. 12 år sedan
ewma.go f9ee67ed7c ewma: ensure 64-bit alignment of uncounted 12 år sedan
ewma_test.go ddac18df1e Benchmarks for everyone! 12 år sedan
gauge.go b29332614c Allow lazy instantiation of metric in GetOrRegister. 11 år sedan
gauge_float64.go 37df06ff62 Do not export methods from sync.Mutex on gauges. 11 år sedan
gauge_float64_test.go 52781178b7 Tidying whitespace. 11 år sedan
gauge_test.go 10aaf9c455 Fully introduce snapshots for all metric types. 12 år sedan
graphite.go 9d393f0a56 Merge branch 'conf_graphite_percentiles' of github.com:kaero/go-metrics 11 år sedan
graphite_test.go 40dc4126bb Allow custom percentiles to report to Graphite 11 år sedan
healthcheck.go 6bd8d76861 Mostly documentation and naming changes. 12 år sedan
histogram.go b29332614c Allow lazy instantiation of metric in GetOrRegister. 11 år sedan
histogram_test.go 6fa35ede17 Fix tests broken by sample changes. 12 år sedan
json.go f47ededb99 use a time.Ticker instead of the time.Sleep 11 år sedan
json_test.go 6d82eb1add Added JSON->io.Writer; consistent ordering to WriteOnce 11 år sedan
log.go 68b130797a initial implementation of GaugeFloat64 11 år sedan
memory.md 033e0dc4eb Installation and usage. 14 år sedan
meter.go f770e6f5e9 Fix Meter.RateMean int64 overflow 11 år sedan
meter_test.go 0c229a5e1b Use a single goroutine for meters. 11 år sedan
metrics.go b953f7c0d8 ETOOCLEVER so s/ObserverEffect/UseNilMetrics/. 12 år sedan
metrics_test.go 68b130797a initial implementation of GaugeFloat64 11 år sedan
opentsdb.go 490281a63d add opentsdb support 11 år sedan
opentsdb_test.go 490281a63d add opentsdb support 11 år sedan
registry.go f51a76fc35 Fix infinite loop in DuplicateMetric.Error 11 år sedan
registry_test.go 426a4331b7 Return an error from Register and disallow dupes 11 år sedan
runtime.go 10272f002f Rework NumGC and PauseNs runtime metrics. 11 år sedan
runtime_test.go 10272f002f Rework NumGC and PauseNs runtime metrics. 11 år sedan
sample.go 9540269a4b Reduce slice re-allocations on UniformSample.Update 11 år sedan
sample_test.go d2ab7a99fa Add test to expose Sample data race 11 år sedan
syslog.go 68b130797a initial implementation of GaugeFloat64 11 år sedan
timer.go b29332614c Allow lazy instantiation of metric in GetOrRegister. 11 år sedan
timer_test.go 6fa35ede17 Fix tests broken by sample changes. 12 år sedan
writer.go 6370c0ca61 Merge branch 'master' of github.com:stuartcarnie/go-metrics 11 år sedan
writer_test.go 6370c0ca61 Merge branch 'master' of github.com:stuartcarnie/go-metrics 11 år sedan

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 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",
})

Periodically upload every metric to Librato:

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

go librato.Librato(metrics.DefaultRegistry,
    10e9,                  // interval
    "example@example.com", // account owner email address
    "token",               // Librato API token
    "hostname",            // source
    []float64{95},         // precentiles to send
    time.Millisecond,      // time unit
)

Periodically emit every metric to StatHat:

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

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

Installation

go get github.com/rcrowley/go-metrics

StatHat support additionally requires their Go client:

go get github.com/stathat/go