Нема описа

mihasya 74c573f630 don't report zero counters. it's expensive. пре 11 година
cmd 68b130797a initial implementation of GaugeFloat64 пре 12 година
influxdb 0f75ec011f Update influxdb.go пре 11 година
librato 74c573f630 don't report zero counters. it's expensive. пре 11 година
stathat 68b130797a initial implementation of GaugeFloat64 пре 12 година
.gitignore 7b8f3191d7 never-read debugging tool. пре 12 година
LICENSE cf3de86166 Updated docs, deleted Makefiles. пре 14 година
README.md de23830573 Use [0,1] value for Librato percentile in Readme пре 11 година
counter.go b29332614c Allow lazy instantiation of metric in GetOrRegister. пре 11 година
counter_test.go 10aaf9c455 Fully introduce snapshots for all metric types. пре 12 година
debug.go 3331190d5f Use time.Tick everywhere else we should, too пре 11 година
debug_test.go a4a3178f75 Skip tests that require GOMAXPROCS > 1. пре 12 година
ewma.go f9ee67ed7c ewma: ensure 64-bit alignment of uncounted пре 12 година
ewma_test.go ddac18df1e Benchmarks for everyone! пре 12 година
gauge.go b29332614c Allow lazy instantiation of metric in GetOrRegister. пре 11 година
gauge_float64.go 37df06ff62 Do not export methods from sync.Mutex on gauges. пре 11 година
gauge_float64_test.go 52781178b7 Tidying whitespace. пре 11 година
gauge_test.go 10aaf9c455 Fully introduce snapshots for all metric types. пре 12 година
graphite.go 9d393f0a56 Merge branch 'conf_graphite_percentiles' of github.com:kaero/go-metrics пре 11 година
graphite_test.go 40dc4126bb Allow custom percentiles to report to Graphite пре 11 година
healthcheck.go 6bd8d76861 Mostly documentation and naming changes. пре 12 година
histogram.go b29332614c Allow lazy instantiation of metric in GetOrRegister. пре 11 година
histogram_test.go 6fa35ede17 Fix tests broken by sample changes. пре 12 година
json.go f47ededb99 use a time.Ticker instead of the time.Sleep пре 11 година
json_test.go 6d82eb1add Added JSON->io.Writer; consistent ordering to WriteOnce пре 11 година
log.go 3331190d5f Use time.Tick everywhere else we should, too пре 11 година
memory.md 033e0dc4eb Installation and usage. пре 14 година
meter.go f770e6f5e9 Fix Meter.RateMean int64 overflow пре 11 година
meter_test.go 0c229a5e1b Use a single goroutine for meters. пре 11 година
metrics.go b953f7c0d8 ETOOCLEVER so s/ObserverEffect/UseNilMetrics/. пре 12 година
metrics_test.go 68b130797a initial implementation of GaugeFloat64 пре 12 година
opentsdb.go 490281a63d add opentsdb support пре 11 година
opentsdb_test.go 490281a63d add opentsdb support пре 11 година
registry.go f51a76fc35 Fix infinite loop in DuplicateMetric.Error пре 11 година
registry_test.go 426a4331b7 Return an error from Register and disallow dupes пре 11 година
runtime.go 3331190d5f Use time.Tick everywhere else we should, too пре 11 година
runtime_cgo.go 6673455b11 (#67) Attempt to build on AppEngine пре 11 година
runtime_no_cgo.go 6673455b11 (#67) Attempt to build on AppEngine пре 11 година
runtime_test.go 10272f002f Rework NumGC and PauseNs runtime metrics. пре 11 година
sample.go 9540269a4b Reduce slice re-allocations on UniformSample.Update пре 11 година
sample_test.go d2ab7a99fa Add test to expose Sample data race пре 11 година
syslog.go 3331190d5f Use time.Tick everywhere else we should, too пре 11 година
timer.go b29332614c Allow lazy instantiation of metric in GetOrRegister. пре 11 година
timer_test.go 6fa35ede17 Fix tests broken by sample changes. пре 12 година
writer.go 3331190d5f Use time.Tick everywhere else we should, too пре 11 година
writer_test.go 6370c0ca61 Merge branch 'master' of github.com:stuartcarnie/go-metrics пре 11 година

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{0.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