Sem descrição

Ralph Caraveo 3a868c8f60 Forgot to handle Mark case há 8 anos atrás
cmd 68b130797a initial implementation of GaugeFloat64 há 12 anos atrás
exp 88a7eacb8a adding exp/ExpHandler so metrics endpoint can be registered on with other HTTP routers há 9 anos atrás
librato 98840580d5 Merge pull request #114 from pressly/master há 10 anos atrás
stathat 68b130797a initial implementation of GaugeFloat64 há 12 anos atrás
.gitignore 7b8f3191d7 never-read debugging tool. há 12 anos atrás
.travis.yml 0201454ee5 Drop support for Go 1.2 há 8 anos atrás
LICENSE cf3de86166 Updated docs, deleted Makefiles. há 14 anos atrás
README.md 7848d21615 Updates README.md with new Honeycomb client há 8 anos atrás
counter.go b29332614c Allow lazy instantiation of metric in GetOrRegister. há 12 anos atrás
counter_test.go 10aaf9c455 Fully introduce snapshots for all metric types. há 12 anos atrás
debug.go 3331190d5f Use time.Tick everywhere else we should, too há 11 anos atrás
debug_test.go a4a3178f75 Skip tests that require GOMAXPROCS > 1. há 12 anos atrás
ewma.go b08b7421c5 Optimizes ewma to reduce lock contention há 8 anos atrás
ewma_test.go 4cdad2ce7c add race test for EWMA há 8 anos atrás
gauge.go 599ea08d1c gofmt the code há 9 anos atrás
gauge_float64.go c8b5fd4aa5 Update gauge_float64.go to reduce lock contention há 8 anos atrás
gauge_float64_test.go 7f3de8a89d Add parallel bench test for gauge_float64 há 8 anos atrás
gauge_test.go 92920137f5 add race test for Gauge há 8 anos atrás
graphite.go 4df3bc4601 deprecate the graphite client in favor of the new separate lib há 10 anos atrás
graphite_test.go 1e6be82bd1 gofmt pass há 10 anos atrás
healthcheck.go 6bd8d76861 Mostly documentation and naming changes. há 12 anos atrás
histogram.go d4f1d62226 Alphabetize há 11 anos atrás
histogram_test.go 6fa35ede17 Fix tests broken by sample changes. há 12 anos atrás
json.go 6eef1fc14e rename "Dump" to "GetAll" há 8 anos atrás
json_test.go 6d82eb1add Added JSON->io.Writer; consistent ordering to WriteOnce há 11 anos atrás
log.go ed93375e3a use interface for logger há 10 anos atrás
memory.md 033e0dc4eb Installation and usage. há 14 anos atrás
meter.go 3a868c8f60 Forgot to handle Mark case há 8 anos atrás
meter_test.go 0d6b050845 add race test for Meter há 8 anos atrás
metrics.go b953f7c0d8 ETOOCLEVER so s/ObserverEffect/UseNilMetrics/. há 12 anos atrás
metrics_test.go 7282ad6453 Document how to create a threadsafe registry há 9 anos atrás
opentsdb.go ddd7a221c0 Fix #74 for OpenTSDB, too há 11 anos atrás
opentsdb_test.go 1e6be82bd1 gofmt pass há 10 anos atrás
registry.go 7b090796d2 Merge pull request #216 from sakateka/dump_registry há 8 anos atrás
registry_test.go 4b2ddcb0bf add Stop() to Timer há 9 anos atrás
runtime.go d180546866 Add thread count metric há 10 anos atrás
runtime_cgo.go 43da0d067c Fixes: Won't compile on AppEngine #67 há 11 anos atrás
runtime_gccpufraction.go 8f4775a23d Add support for fraction of CPU time used by GC há 10 anos atrás
runtime_no_cgo.go 43da0d067c Fixes: Won't compile on AppEngine #67 há 11 anos atrás
runtime_no_gccpufraction.go 8f4775a23d Add support for fraction of CPU time used by GC há 10 anos atrás
runtime_test.go d180546866 Add thread count metric há 10 anos atrás
sample.go 1f30fe9094 Merge pull request #97 from Dieterbe/ExpDecaySample-url há 9 anos atrás
sample_test.go 670402e738 Test for #104 há 10 anos atrás
syslog.go 3331190d5f Use time.Tick everywhere else we should, too há 11 anos atrás
timer.go 9180854cf5 Use set of meters and update documentation há 8 anos atrás
timer_test.go 4b2ddcb0bf add Stop() to Timer há 9 anos atrás
validate.sh 0af305c4e3 more go versions; add race detector to tests há 8 anos atrás
writer.go 3331190d5f Use time.Tick everywhere else we should, too há 11 anos atrás
writer_test.go 6370c0ca61 Merge branch 'master' of github.com:stuartcarnie/go-metrics há 11 anos atrás

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)

r := NewRegistry()
g := metrics.NewRegisteredFunctionalGauge("cache-evictions", r, func() int64 { return cache.getEvictionsCount() })

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)

Register() is not threadsafe. For threadsafe metric registration use GetOrRegister:

t := metrics.GetOrRegisterTimer("account.create.latency", nil)
t.Time(func() {})
t.Update(47)

NOTE: Be sure to unregister short-lived meters and timers otherwise they will leak memory:

// Will call Stop() on the Meter to allow for garbage collection
metrics.Unregister("quux")
// Or similarly for a Timer that embeds a Meter
metrics.Unregister("bang")

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/vrischmann/go-metrics-influxdb"

go influxdb.InfluxDB(metrics.DefaultRegistry,
  10e9, 
  "127.0.0.1:8086", 
  "database-name", 
  "username", 
  "password"
)

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

Maintain all metrics along with expvars at /debug/metrics:

This uses the same mechanism as the official expvar but exposed under /debug/metrics, which shows a json representation of all your usual expvars as well as all your go-metrics.

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

exp.Exp(metrics.DefaultRegistry)

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: