Nav apraksta

Mikhail P da893417b5 Merge pull request #107 from pjvds/master 10 gadi atpakaļ
cmd 68b130797a initial implementation of GaugeFloat64 11 gadi atpakaļ
librato 98840580d5 Merge pull request #114 from pressly/master 10 gadi atpakaļ
stathat 68b130797a initial implementation of GaugeFloat64 11 gadi atpakaļ
.gitignore 7b8f3191d7 never-read debugging tool. 12 gadi atpakaļ
.travis.yml cd3ffa4e4e improve build latency 10 gadi atpakaļ
LICENSE cf3de86166 Updated docs, deleted Makefiles. 13 gadi atpakaļ
README.md da893417b5 Merge pull request #107 from pjvds/master 10 gadi atpakaļ
counter.go b29332614c Allow lazy instantiation of metric in GetOrRegister. 11 gadi atpakaļ
counter_test.go 10aaf9c455 Fully introduce snapshots for all metric types. 12 gadi atpakaļ
debug.go 3331190d5f Use time.Tick everywhere else we should, too 11 gadi atpakaļ
debug_test.go a4a3178f75 Skip tests that require GOMAXPROCS > 1. 12 gadi atpakaļ
ewma.go 1e6be82bd1 gofmt pass 10 gadi atpakaļ
ewma_test.go ddac18df1e Benchmarks for everyone! 12 gadi atpakaļ
gauge.go b29332614c Allow lazy instantiation of metric in GetOrRegister. 11 gadi atpakaļ
gauge_float64.go 37df06ff62 Do not export methods from sync.Mutex on gauges. 11 gadi atpakaļ
gauge_float64_test.go 52781178b7 Tidying whitespace. 11 gadi atpakaļ
gauge_test.go 10aaf9c455 Fully introduce snapshots for all metric types. 12 gadi atpakaļ
graphite.go 4df3bc4601 deprecate the graphite client in favor of the new separate lib 10 gadi atpakaļ
graphite_test.go 1e6be82bd1 gofmt pass 10 gadi atpakaļ
healthcheck.go 6bd8d76861 Mostly documentation and naming changes. 12 gadi atpakaļ
histogram.go d4f1d62226 Alphabetize 11 gadi atpakaļ
histogram_test.go 6fa35ede17 Fix tests broken by sample changes. 12 gadi atpakaļ
json.go 7f86fc7d84 Fix registry race caused by copying a sync.Mutex 11 gadi atpakaļ
json_test.go 6d82eb1add Added JSON->io.Writer; consistent ordering to WriteOnce 11 gadi atpakaļ
log.go 304718cefc include duration's unit in printed metrics 10 gadi atpakaļ
memory.md 033e0dc4eb Installation and usage. 14 gadi atpakaļ
meter.go f770e6f5e9 Fix Meter.RateMean int64 overflow 11 gadi atpakaļ
meter_test.go 0c229a5e1b Use a single goroutine for meters. 11 gadi atpakaļ
metrics.go b953f7c0d8 ETOOCLEVER so s/ObserverEffect/UseNilMetrics/. 12 gadi atpakaļ
metrics_test.go 68b130797a initial implementation of GaugeFloat64 11 gadi atpakaļ
opentsdb.go ddd7a221c0 Fix #74 for OpenTSDB, too 11 gadi atpakaļ
opentsdb_test.go 1e6be82bd1 gofmt pass 10 gadi atpakaļ
registry.go 2ace5d04c3 Add a prefixed registry 10 gadi atpakaļ
registry_test.go 2ace5d04c3 Add a prefixed registry 10 gadi atpakaļ
runtime.go db420d79fc Fix reporting for NumCgoCall() and apply go fmt 11 gadi atpakaļ
runtime_cgo.go 43da0d067c Fixes: Won't compile on AppEngine #67 11 gadi atpakaļ
runtime_no_cgo.go 43da0d067c Fixes: Won't compile on AppEngine #67 11 gadi atpakaļ
runtime_test.go 10272f002f Rework NumGC and PauseNs runtime metrics. 11 gadi atpakaļ
sample.go a5cfc242a5 Prevent most allocations in ExpDecaySample 10 gadi atpakaļ
sample_test.go 670402e738 Test for #104 10 gadi atpakaļ
syslog.go 3331190d5f Use time.Tick everywhere else we should, too 11 gadi atpakaļ
timer.go d4f1d62226 Alphabetize 11 gadi atpakaļ
timer_test.go 6fa35ede17 Fix tests broken by sample changes. 12 gadi atpakaļ
validate.sh c76eeb4d84 first attempt at basic travis build 10 gadi atpakaļ
writer.go 3331190d5f Use time.Tick everywhere else we should, too 11 gadi atpakaļ
writer_test.go 6370c0ca61 Merge branch 'master' of github.com:stuartcarnie/go-metrics 11 gadi atpakaļ

README.md

go-metrics

travis build status

Go port of Coda Hale's Metrics library: https://github.com/dropwizard/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, 5 * time.Second, 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 using the Graphite client:


import "github.com/cyberdelia/go-metrics-graphite"

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

Periodically emit every metric into InfluxDB:

NOTE: this has been pulled out of the library due to constant fluctuations in the InfluxDB API. In fact, all client libraries are on their way out. see issues #121 and #124 for progress and details.

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 using the Librato client:

Note: the client included with this repository under the librato package has been deprecated and moved to the repository linked above.

import "github.com/mihasya/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

Publishing Metrics

Clients are available for the following destinations: