Žiadny popis

Thiago Caiubi d89aab3595 Fix typo 10 rokov pred
cmd 68b130797a initial implementation of GaugeFloat64 11 rokov pred
influxdb 0f75ec011f Update influxdb.go 11 rokov pred
librato a924b1eb25 coerce timestamps so graphs from disparate sources line up 11 rokov pred
stathat 68b130797a initial implementation of GaugeFloat64 11 rokov pred
.gitignore 7b8f3191d7 never-read debugging tool. 12 rokov pred
LICENSE cf3de86166 Updated docs, deleted Makefiles. 14 rokov pred
README.md d89aab3595 Fix typo 10 rokov pred
counter.go b29332614c Allow lazy instantiation of metric in GetOrRegister. 11 rokov pred
counter_test.go 10aaf9c455 Fully introduce snapshots for all metric types. 12 rokov pred
debug.go 3331190d5f Use time.Tick everywhere else we should, too 11 rokov pred
debug_test.go a4a3178f75 Skip tests that require GOMAXPROCS > 1. 12 rokov pred
ewma.go f9ee67ed7c ewma: ensure 64-bit alignment of uncounted 12 rokov pred
ewma_test.go ddac18df1e Benchmarks for everyone! 12 rokov pred
gauge.go b29332614c Allow lazy instantiation of metric in GetOrRegister. 11 rokov pred
gauge_float64.go 37df06ff62 Do not export methods from sync.Mutex on gauges. 11 rokov pred
gauge_float64_test.go 52781178b7 Tidying whitespace. 11 rokov pred
gauge_test.go 10aaf9c455 Fully introduce snapshots for all metric types. 12 rokov pred
graphite.go 8307929d05 Merge remote-tracking branch 'pteichman/durations' 11 rokov pred
graphite_test.go 40dc4126bb Allow custom percentiles to report to Graphite 11 rokov pred
healthcheck.go 6bd8d76861 Mostly documentation and naming changes. 12 rokov pred
histogram.go d4f1d62226 Alphabetize 11 rokov pred
histogram_test.go 6fa35ede17 Fix tests broken by sample changes. 12 rokov pred
json.go f47ededb99 use a time.Ticker instead of the time.Sleep 11 rokov pred
json_test.go 6d82eb1add Added JSON->io.Writer; consistent ordering to WriteOnce 11 rokov pred
log.go 3331190d5f Use time.Tick everywhere else we should, too 11 rokov pred
memory.md 033e0dc4eb Installation and usage. 14 rokov pred
meter.go f770e6f5e9 Fix Meter.RateMean int64 overflow 11 rokov pred
meter_test.go 0c229a5e1b Use a single goroutine for meters. 11 rokov pred
metrics.go b953f7c0d8 ETOOCLEVER so s/ObserverEffect/UseNilMetrics/. 12 rokov pred
metrics_test.go 68b130797a initial implementation of GaugeFloat64 11 rokov pred
opentsdb.go ddd7a221c0 Fix #74 for OpenTSDB, too 11 rokov pred
opentsdb_test.go 490281a63d add opentsdb support 11 rokov pred
registry.go dee209f245 (#86) Add UnregisterAll to Registry and StandardRegistry 11 rokov pred
registry_test.go 426a4331b7 Return an error from Register and disallow dupes 11 rokov pred
runtime.go db420d79fc Fix reporting for NumCgoCall() and apply go fmt 11 rokov pred
runtime_cgo.go 43da0d067c Fixes: Won't compile on AppEngine #67 11 rokov pred
runtime_no_cgo.go 43da0d067c Fixes: Won't compile on AppEngine #67 11 rokov pred
runtime_test.go 10272f002f Rework NumGC and PauseNs runtime metrics. 11 rokov pred
sample.go a1ae257e5f Added comment about the source of the heap implementation. 11 rokov pred
sample_test.go d2ab7a99fa Add test to expose Sample data race 11 rokov pred
syslog.go 3331190d5f Use time.Tick everywhere else we should, too 11 rokov pred
timer.go d4f1d62226 Alphabetize 11 rokov pred
timer_test.go 6fa35ede17 Fix tests broken by sample changes. 12 rokov pred
writer.go 3331190d5f Use time.Tick everywhere else we should, too 11 rokov pred
writer_test.go 6370c0ca61 Merge branch 'master' of github.com:stuartcarnie/go-metrics 11 rokov pred

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},       // percentiles 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