Нема описа

mihasya 22d219e7f2 [fixes #188] expose a constructor for SampleSnapshot пре 9 година
cmd 68b130797a initial implementation of GaugeFloat64 пре 11 година
exp 88a7eacb8a adding exp/ExpHandler so metrics endpoint can be registered on with other HTTP routers пре 9 година
librato 98840580d5 Merge pull request #114 from pressly/master пре 10 година
stathat 68b130797a initial implementation of GaugeFloat64 пре 11 година
.gitignore 7b8f3191d7 never-read debugging tool. пре 12 година
.travis.yml 680c681b56 Add support for Golang 1.5 in Travis CI пре 10 година
LICENSE cf3de86166 Updated docs, deleted Makefiles. пре 13 година
README.md 800344da39 Fix typo for link to Ganglia пре 9 година
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 1e6be82bd1 gofmt pass пре 10 година
ewma_test.go ddac18df1e Benchmarks for everyone! пре 12 година
gauge.go e19570827a Adding FunctionalGauge пре 9 година
gauge_float64.go e19570827a Adding FunctionalGauge пре 9 година
gauge_float64_test.go e19570827a Adding FunctionalGauge пре 9 година
gauge_test.go 7282ad6453 Document how to create a threadsafe registry пре 9 година
graphite.go 4df3bc4601 deprecate the graphite client in favor of the new separate lib пре 10 година
graphite_test.go 1e6be82bd1 gofmt pass пре 10 година
healthcheck.go 6bd8d76861 Mostly documentation and naming changes. пре 12 година
histogram.go d4f1d62226 Alphabetize пре 11 година
histogram_test.go 6fa35ede17 Fix tests broken by sample changes. пре 12 година
json.go 78329dab49 Support JSON marshalling of PrefixedRegistry. пре 9 година
json_test.go 6d82eb1add Added JSON->io.Writer; consistent ordering to WriteOnce пре 11 година
log.go ed93375e3a use interface for logger пре 9 година
memory.md 033e0dc4eb Installation and usage. пре 14 година
meter.go f770e6f5e9 Fix Meter.RateMean int64 overflow пре 11 година
meter_test.go c0a2e033c3 Fix race condition on test пре 10 година
metrics.go b953f7c0d8 ETOOCLEVER so s/ObserverEffect/UseNilMetrics/. пре 12 година
metrics_test.go 7282ad6453 Document how to create a threadsafe registry пре 9 година
opentsdb.go ddd7a221c0 Fix #74 for OpenTSDB, too пре 11 година
opentsdb_test.go 1e6be82bd1 gofmt pass пре 10 година
registry.go f9330b997b Address PR comments пре 9 година
registry_test.go f9330b997b Address PR comments пре 9 година
runtime.go d180546866 Add thread count metric пре 10 година
runtime_cgo.go 43da0d067c Fixes: Won't compile on AppEngine #67 пре 11 година
runtime_gccpufraction.go 8f4775a23d Add support for fraction of CPU time used by GC пре 10 година
runtime_no_cgo.go 43da0d067c Fixes: Won't compile on AppEngine #67 пре 11 година
runtime_no_gccpufraction.go 8f4775a23d Add support for fraction of CPU time used by GC пре 10 година
runtime_test.go d180546866 Add thread count metric пре 10 година
sample.go 22d219e7f2 [fixes #188] expose a constructor for SampleSnapshot пре 9 година
sample_test.go 670402e738 Test for #104 пре 10 година
syslog.go 3331190d5f Use time.Tick everywhere else we should, too пре 11 година
timer.go d4f1d62226 Alphabetize пре 11 година
timer_test.go 7282ad6453 Document how to create a threadsafe registry пре 9 година
validate.sh c76eeb4d84 first attempt at basic travis build пре 10 година
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

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)

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

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: